Jquery-ui自动完成选择回叫功能无法正常工作

时间:2012-10-25 08:42:43

标签: jquery asp.net-mvc asp.net-mvc-3 jquery-ui jquery-ui-autocomplete

我正在使用jquery-ui自动完成并在自动完成功能中进行ajax调用我正在调用我的控制器动作返回Json,每件事情都运行良好但是当我从建议下拉列表中选择一些东西然后select调用在select回调函数ui中调用的后退函数未定义。

Javascript

 function log(message) {
            $("<div>").text(message).prependTo("#log");
            $("#log").scrollTop(0);
        }

        $("#search").autocomplete({
            source: function (request, response) {
                $.ajax({
                    url: "/Home/GetCompanyNames",
                    dataType: "jsonp",
                    data: "searchterm=" + request.term,
                    success: function (data) {
                        response($.map(data, function (item) {
                            alert(item.Value);
                            return {
                                label: item.Name,
                                value: item.Name
                            };
                        }));
                    }
                });
            },
            minLength: 2,
            select: function (event, ui) {
                alert(ui.item.Name);
            alert(ui.item.Value);
            alert(ui.item.LogoUrl);
            },
            open: function () {
                $(this).removeClass("ui-corner-all").addClass("ui-corner-top");
            },
            close: function () {
                $(this).removeClass("ui-corner-top").addClass("ui-corner-all");
            }
        });

    });

控制器中的操作:

    public JsonResult GetCompanyNames (string searchterm)
    {
        var companies = context.companyService.Query().Where(x => x.Name.Contains(searchterm)).ToList();
        var list = companies.Select(item => new SearchJsonModel
                                                {
                                                    LogoUrl = item.Logo != null || item.Logo != "" ? "<img  src='/Upload/" + item.Logo + "' />" : "<img src='/home/image?image=" + item.Name + "' />", Name = item.Name, Value = item.InternetName
                                                }).Select(model => (model)).ToList();
        return Json(list, JsonRequestBehavior.AllowGet);
    }

SearchJsonModel:

 public class SearchJsonModel
{
    public string Name { get; set; }
    public string Value { get; set; }
    public string LogoUrl { get; set; }
}

如果您需要更多细节并提前致谢,请询问我。

1 个答案:

答案 0 :(得分:0)

要获取Name,Value,LogoUrl,请将响应设置为:

response($.map(data, function (item) {
                        alert(item.Value);
                        return {
                            label: item.Name,
                            value: item.Name
                            LogoUrl: item.LogoUrl,
                            Name: item.Name 
                        };