自动完成json数据 - 如何在MVC3 Razor中使用它

时间:2012-06-04 17:56:05

标签: jquery asp.net-mvc-3

当我的jQuery自动完成函数获取json数据项时,如何获取所选项并将其分配给我的DOM中的其他文本框?

我是否在文本框中连接了一个事件?

我的js:

$(document).ready(function () {
$("#CustByName").autocomplete(
    {
        source: function (request, response) {
            $.ajax(
            {
                url: "/Cases/FindByName", type: "GET", dataType: "json",
                data: { searchText: request.term, maxResults: 10 },
                contentType: "application/json; charset=utf-8",
                success: function (data) {
                    response($.map(data, function (item) {
                        return {
                            label: item.CustomerName,
                            value: item.CustomerName,
                            id: item.CustomerID
                        }
                    })
                    );
                }
            });
        },
        minLength: 3
    });

});

和我的控制器动作:

//Post: autocomplete customer names
    //[HttpPost]
    public JsonResult FindByName(string searchText, int maxResults)
        {
        CustomerFind find = new CustomerFind();
        var result = find.FindCustomerByName(searchText, maxResults);
        return Json(result, JsonRequestBehavior.AllowGet);
        }

和我的FindCustomerByName函数

internal List<Models.Customer> FindCustomerByName(string searchText, int maxResults)
        {
        List<Models.Customer> result;

        using (cummins_sqldb dataContext = new cummins_sqldb())
            {

            result = (from c in dataContext.Customers
                      where c.CustomerName.Contains(searchText)
                      orderby c.CustomerName
                      select c).Take(maxResults).ToList();
            }
        return result;

        }

0 个答案:

没有答案