ASP.NET Web API é um framework para construir APIs web em cima do .NET Framework. Neste tutorial, vou mostrar com fazer um simples AutoComplete usando WebApi retornando JSON e Jquery UI. É necessário Visual Studio 2010/2012 com o template do ASP.NET MVC 4 Project instalados.
Criando o projeto Web Api
No Visual Studio, para um novo projeto:
- File->New Project-> Templates->Installed Templates->Visual C#->ASP.NET MVC 4 Web Application
- Na janela selecione Web API.
- Adicione referência para
System.Web.Http.WebHost
. - Adicione o arquivo
App_Start\WebApiConfig.cs
(use como exemplo o código do post). - Adicione using
System.Web.Http
inGlobal.asax.cs
. - Chame
WebApiConfig.Register(GlobalConfiguration.Configuration)
na função StartGlobal.asax.cs
, antes da rota MVC, por causa de sua precedência.
Criando o Modelo AutoComplete
Para criar o nosso resultado JSON vou usar um modelo que pode ser reutilizado toda vez que precisarmos da funcionalidade, chamado AutoCompleteModel. Esse modelo possui os campos padrão que a função do Jquery UI utiliza. Segundo a documentação oficial pode ser de duas maneiras:
- Lista de Strings:
[ "Choice1", "Choice2" ]
- Array de objetos com as propriedades
label
evalue
:[ { label: "Choice1", value: "value1" }, ... ]
Neste exemplo vou trabalhar com o Array de objetos, que será representado pelo objeto AutoComplete. Na maioria dos casos o desenvolvedor trabalha neste modelo, dado que é necessário usar o Value, que pode representar uma chave primária ou outra informação que será essencial para executar alguma lógica ao submeter o form.
Model/AutoCompleteModel.cs
Criando nossa API
Nossa API será bem simples, vamos criar uma Action que retorne uma lista de AutoComplete passando como parametro uma string com nome term. Fica como observação que term é o nome padrão que o Jquery UI AutoComplete usa na requisição, logo seu método action deve receber exatamente esse nome nesse caso.Controller/AutoCompleteController.cs
Especificando AcceptVerbs na Action nos permite que chamemos nosso método como api/AutoComplete/Cars. Mas fazendo isso se faz necessário especificar também o método, no nosso caso é um GET, então HttpGet. Isso é somente perfumaria, para que fique mais legível a url.
Configurando a API
A configuração de rotas que vou usar é a que vem por padrão no projeto. Uma coisa que deve ser mudada está relacionado com o Formatter. Por padrão, o Formatter utilizado no Web Api é o XML, mas no nosso caso queremos JSON. Outra coisa está relacionada ao nome das propriedades, dado que em nosso modelo elas estão em case diferente do que é requerido pela função (está Value, precisa ser value).
App_Start/WebApiConfig.cs
Nossa Api já está funcionando, podemos acessá-la pelo próprio browser.
Criando os campos View
Na View haverão dois campos: um input que será usado para autocomplete e um div de log que receberá o que for selecionado. Eu usei basicamente o mesmo html que está no site de referência do Jquery UI Autocomplete.
Views/Home/Index.cshtml
Esse HTML nos dá como resultado o seguinte:
Criando a função JavaScript
Para o auto complete foi usado o Jquery UI AutoComplete. O exemplo é simples, vamos consultar remotamente nosso caminho de API, retornar um JSON já no formato esperado e ao selecionarmos um elemento esse será colocado no campo Result. A função foi baseada no exemplo do site oficial do Jquery, fiz algumas alterações apenas para adequar o source a nosso local e os nomes dos campos que mudei.
Views/Home/Index.cshtml
Finalizando
Já com tudo pronto é possível utilizar nosso autocomplete. Ao digitar dois ou mais caracteres o campo exibe as opções de busca.
Ao selecionar um registro, é adicionado ao Log.
Web API e JSON trazem benéfícios impressionantes em relação a banda. A requisição dessa lista auto complete por exemplo não passou de 502 bytes. Espero que tenham gostado, o exemplo pode ser baixado aqui.
Muito bom seu post. Vou precisar muito disso...Vlw Filipe!
ResponderExcluirAchei algo muito legal, e deseja que nosso Grande Deus, ilumine vossa carreira; pois são pessoas assim, que o planeta terra precisa.
ResponderExcluir