Java Script Variável Global

Quem nunca sofreu usando uma variável java script que era global e  não sabíamos e por causa desse pequeno descuido ficamos horas e horas procurando o erro.
Abaixo tem um simples modelo que  pode nos ajudar no nosso dia a dia.

//Variavel Global

MinhaAplicacao =
{
Nome:"Juliano",
SobreNome:"Sales"
}

//Utilizando ela dentro de um objeto

var Pessoa  = {
getNome:function(){
return MinhaAplicacao.Nome;
},
getSobreNome:function(){
return MinhaAplicacao.SobreNome;
}
}

//Escrevendo e chamando nosso objeto
document.writeln(Pessoa.getNome())

document.writeln(Pessoa.SobreNome())



Jquery + Asp.net MVC – Parte 1



Depois de ficar algum tempo sem publicar artigos resolvi fazer um série de artigos sobre Jquery + Asp.net MVC, para mostrar como que podemos usar essa poderosas ferramentas no nosso dia a dia.
Por que vamos usar Jquery ?
E uma excelente  biblioteca Java Script  rápida que podemos manipular o documento HTML, com essa biblioteca podemos criar animações, manipular eventos e fazer grandes interações AJAX .
Por que Asp.net MVC ?
Precisamos controlar bem o HTML , precisamos usar  um excelente padrão de projeto que separe bem as camadas,precisamos trabalhar com uma ferramenta que seja realmente focada para web “desculpa webforms”.

1 – Objetivo do artigo e ensinar a  fazer requisições Ajax utilizando Jquery + Asp.net MVC
No jquery temos varias  maneira de fazer requisições Ajax, abaixo vou listar as mais conhecidas, lembrando que no endereço http://api.jquery.com/category/ajax/, podemos  descobrir toda as características de cada método
1 -  $.post
2 – $.get
3 - $.getJson
4 - $.ajax
5 - $.load
Para começarmos o tutorial precisamos ter a seguinte configuração no Visual Studio e uma pequena visão parcial no padrão de Projeto MVC .
Visual Studio: Frame work.4.0,Asp.net MVC 3, caso o  seu Visual Studio não tenha o MVC3 podemos instalar a partir desse link http://www.microsoft.com/web/gallery/install.aspx?appid=VWDorVS2010SP1Pack




1 – Inicie o visual Studio, clique em File > New Project > nome do projeto > clique no botão ok > Empty > clique no botão ok




2 – Como nos estamos criamos um projeto a partir do zero temos que criar um Controller e depois criar um View. Clique com o botão direito do mouse sobre a pasta Controllers > add > Controller > nome do Controle >clique no botão Add.



Depois que criamos o controle precisamos criar uma View para esse controle, clique com o botão direito do mouse sobre  o nome da ActionResult  e clique na opção Add View, depois clique em Add.


Na aba do Solution Explorer note que o visual Studio criou o seguinte estrutura na Views/Cadastro/Index.cshtml



3 – Na Index.cshtml vamos criar um formulário básico com os seguintes campos nome,e-mail e um botão com o value enviar dados, e vamos  criar uma div abaixo do botão, assim que o usuário clicar no botão enviar dados vamos processar as informações no servidor e vamos devolver o resultado do processamento dentro da div.


4 – Agora precisamos adicionar a biblioteca jquery na página, na Solution Explorer  acesse a pasta Scripts          arraste o arquivo jquery-1.6.2.js antes da tag <h2> da página . Uma vez adicionado à biblioteca podemos escrever nosso código Java Script.

No exemplo abaixo estamos usando o método $.ajax , dentro do método podemos definir como vai ser o tipo da submissão dos dados através da opção  type, e também podemos apontar quem vai receber esses dados através da opção url, na opção data  estamos passando os valores do formulário, na opção sucess  como o nome já diz  sucesso, depois de processar no servidor ele retornara o nome e o e-mail que o usuário preencheu , depois jogamos a variável data dentro do atributo HTML , ou seja a nossa div resultado vai receber as informações processada pelo servidor
<script type="text/javascript">
    //Preparando a nossa função
    $(document).ready(function () {
        //Quando o Botão "btnCadastrar"  for clicado
        $("#btnCadastrar").click(function () {
            $.ajax({
                type:'POST',
                url: '/Cadastro/Cadastrar/',
                data:$("#frmCadastro").serialize(),
                success: function(data) {
                    $('#resultado').html(data);
                }
            });
        });
    });
</script>



5 – Precisamos  acessar a nossa Controller Cadastro  e criar um método chamado Cadastrar como no exemplo abaixo, note que antes do método coloquei  um atributo httPost ou seja será apenas possível acessar esse método através de uma requisição do tipo POST.
 [HttpPost]
        public string Cadastrar(FormCollection formulario)
        {
            string retorno = null;
            retorno = "Nome :" + formulario["nome"] + " E-mail" + formulario["email"];

            return retorno;
        }






7 – Antes  de testar nosso projeto  temos que configurar nossa Global.asax.cs,  temos que alterar o método  RegisterRoutes, por padrão ele deixa setado o valor controller  com a controle  Home.
public static void RegisterRoutes(RouteCollection routes)
        {
            routes.IgnoreRoute("{resource}.axd/{*pathInfo}");

            routes.MapRoute(
                "Default", // Route name
                "{controller}/{action}/{id}", // URL with parameters
                new { controller = "Home", action = "Index", id = UrlParameter.Optional } // Parameter defaults
            );

        }
Para
public static void RegisterRoutes(RouteCollection routes)
        {
            routes.IgnoreRoute("{resource}.axd/{*pathInfo}");

            routes.MapRoute(
                "Default", // Route name
                "{controller}/{action}/{id}", // URL with parameters
                new { controller = "Cadastro", action = "Index", id = UrlParameter.Optional } // Parameter defaults
            );

        }

6 – Resultados da requisição Ajax


Nesse artigo tivemos uma pequena amostra  que podemos fazer usando JQUERY + ASP.NET  MVC, nos próximos artigos vamos aprofundar ainda mais nos recursos dessa poderosa biblioteca jquery.
Para saber mais visite os links abaixo.

Validação de formulário com jquery

Muitas vezes precisamos validar formulários em Java script e raramente aproveitamos o código, mais graças ao Jquery descobri uma forma simples de validar os campos obrigatórios.
“Estrutura do HTML”
<form>
<label for=”nome”>Nome</label>
<input type=”text” id=”nome” name=”nome” value=”" class=”required”>
<label for=”email”>E-mail</label>
<input type=”text” id=”email” name=”email” value=”" class=”required”>
<label for=”senha”>Senha</label>
<input type=”password” id=”senha” name=”senha” value=”" class=”required”>
<input type=”button” id=”btnCadastrar” name=”btnCadastrar” value=”Cadastrar”>
</form>
Em cada  INPUT  acrescentei um classe required, ela representa que  ele é um campo obrigatório.
<input type=”text” id=”nome” name=”nome” value=”" class=”required”>
Java Script
Dentro da tag  HEAD acrescentei o codigo abaixo
<script type=”text/javascript” src=”http://code.jquery.com/jquery-1.7.1.min.js”></script>
<script type=”text/javascript”>
$(document).ready(function(){
$(“#btnCadastrar”).click(function(){
$(“.required”).each(function(){
if($(this).val()==”"){
alert(“Campo obrigatório!”);
$(this).focus();
return false;
}
});
});
});
</script>
</head>
“Descrevendo o código”
Quando o botão Cadastrar for clicado ele vai disparar uma função,  a função vai percorrer os elementos que tiver a classe “required”  e  vai verificar se existe algum elemento que contem um campo vazio, caso ela encontre, vai exibir um alerta e vai adicionar o foco para o campo  que se encontra vazio .
“Segue abaixo o código completo, lembrando que é apenas um exemplo da  simplicidade do Jquery podemos desenvolver várias formas para melhorar a função demonstrada nesse tutorial, sem mais delongas boa sorte .. ”
<!DOCTYPE html>
<html>
<head>
<meta content=”text/html; charset=utf-8″ http-equiv=”Content-Type”>
<title>Jquery </title>
<script type=”text/javascript” src=”http://code.jquery.com/jquery-1.7.1.min.js”></script>
<script type=”text/javascript”>
$(document).ready(function(){
$(“#btnCadastrar”).click(function(){
$(“.required”).each(function(){
if($(this).val()==”"){
alert(“Campo obrigatório!”);
$(this).focus();
return false;
}
});
});
});
</script>
</head>
<body>
<form>
<label for=”nome”>Nome</label>
<input type=”text” id=”nome” name=”nome” value=”" class=”required”>
<label for=”email”>E-mail</label>
<input type=”text” id=”email” name=”email” value=”" class=”required”>
<label for=”senha”>Senha</label>
<input type=”password” id=”senha” name=”senha” value=”" class=”required”>
<input type=”button” id=”btnCadastrar” name=”btnCadastrar” value=”Cadastrar”>
</form>
</body>
</html>