Автозаполнение JQuery + Asp.net MVC - PullRequest
0 голосов
/ 25 ноября 2010

Я использую плагин автозаполнения JQuery в своем проекте Asp.net MVC.Пока что я возвращаю список строк из моего метода поиска, и эти строки отображаются правильно.

В моем представлении:

<script type="text/javascript">
  $(function () {
  $("#search").autocomplete({
  source: '<%: Url.Action("Search") %>',
  minLength: 1
   });
  });
</script>

Контроллер:

 public JsonResult Search(string term)
{
  //search Code here ...  
  var dt = ....;
  var result = new List<string>();
  //search Code returns a DataTable, which I convert into a List<string>

    for (int i = 0; i < dt.Rows.Count; i++)
    {
      result.Add(...);
    }

  //return List<string> to the autocomplete plugin
  return Json(result, JsonRequestBehavior.AllowGet);
}

Интересно, возможно ли вернуть объект DataTable и отобразить DataTable в HTML-таблице.Или можно вернуть HTML-таблицу?Кто-нибудь пробовал что-то подобное?

Большое спасибо

Jaspis

Ответы [ 2 ]

1 голос
/ 27 апреля 2013

Шаг 1. Подготовка веб-интерфейса API

Давайте сначала создадим метод веб-API , который будет возвращать список элементов (исполнителей), используя поисковый запрос запрос , отправленный из текстового поля автозаполнения. В этом посте я не использую базу данных, вместо этого я буду использовать List, чтобы сделать этот пример максимально простым.

Ниже я определил свой класс Artist

public class Artist
{
    public int Id { get; set; }
    public int Name { get; set; }
}    

Далее я создал GET-метод Web Api , который будет использовать поисковый термин, введенный в текстовое поле автозаполнения, и с небольшой помощью LINQ вернет список результатов поиска.

using System.Collections.Generic;
using System.Linq;
using System.Web.Http;

namespace Autocomplete.Controllers
{
    public class ArtistApiController : ApiController
    {

        public List<Artist> ArtistList = new List<Artist>
        {
            new Artist{Id = 1, Name = "Sonu Nigam"},
            new Artist{Id = 2, Name = "Sunidhi Chauhan"},
            new Artist{Id = 3, Name = "Shreya Goshal"},
            new Artist{Id = 4, Name = "Mohit Chauhan"},
            new Artist{Id = 5, Name = "Nihkil Dsouza"},
            new Artist{Id = 6, Name = "Kailash Kher"},
            new Artist{Id = 7, Name = "Atif Aslam"},
            new Artist{Id = 8, Name = "Ali Zafar"},
            new Artist{Id = 9, Name = "Shafaqat Ali"},
            new Artist{Id = 10, Name = "Shankar Madahevan"}
        }; 


        // GET api/values
        public IEnumerable<Artist> Get(string query)
        {
            return ArtistList.Where(m => m.Name.Contains(query)).ToList();
        }
    }
}   

Наш серверный код готов! Время проверить это.

enter image description here

Шаг 2: код на стороне клиента

Включите jquery-ui.js и jquery.ui.css в ваш html

<script type="text/javascript" src="~/Scripts/jquery-1.7.1.min.js" ></script>
<script type="text/javascript" src="~/Scripts/jquery-ui-1.8.20.min.js" ></script>
<link href="~/Content/themes/base/jquery.ui.all.css" rel="stylesheet" />

<div id="body">
    <label for="autocomplete-textbox">Search : </label>
    <input type="text" id="autocomplete-textbox" />
</div>

<script type="text/javascript">
$(document).ready(function (){
$('#autocomplete-textbox').autocomplete({
    source: function (request, response) {
        // prepare url : for example '/api/artistapi?query=sonu
        var autocompleteUrl = '/api/artistapi' + '?query=' + request.term;
        $.ajax({
            url: autocompleteUrl,
            type: 'GET',
            cache: false,
            dataType: 'json',
            success: function (json) {
                // call autocomplete callback method with results  
                response($.map(json, function (data, id) {
                    return {
                        label: data.Name,
                        value: data.Id
                    };
                }));
            },
            error: function (xmlHttpRequest, textStatus, errorThrown) {
                console.log('some error occured', textStatus, errorThrown);
            }
        });
    },
    minLength: 2,
    select: function (event, ui) {
        alert('you have selected ' + ui.item.label + ' ID: ' + ui.item.value);
        $('#autocomplete-textbox').val(ui.item.label);
        return false;
    }
});
});
</script>

Здесь следует отметить, что в методе успеха я использовал следующий код:

response($.map(json, function (data, id) {
    return {
        label: data.Name,
        value: data.Id
    };
}));

data.Id и data.Name используется, поскольку в ответе ajax (как показано ниже) данные возвращаются в этом формате.

enter image description here

Шаг 3: Проверка и вывод:

enter image description here

Взято с здесь

0 голосов
/ 25 ноября 2010

Вы можете взглянуть на пользовательские данные и отобразить образец.

...