首页 > 解决方案 > asp mvc中的自动完成脚本

问题描述

嗨,我是网页开发的新手,验证了 Stack over flow 中的所有相关问题,但我仍然无法获得解决方案。

我正在尝试在输入框中包含自动完成功能,并且如果我Layout = null;在视图文件中它可以正常工作,就像我使用现有的视图模板ViewBag.Title = "Home Page";自动完成功能不起作用一样

查看文件:

@model IEnumerable<AspNetRoleBasedSecurity.Models.PostModel>
@{
ViewBag.Title = "Home Page";
}

<div class="row search-row">
<input class="search ui-autocomplete-input" type="text" id="CityName" placeholder="What do you need help with?"/>
<a class="buttonsearch btn btn-info btn-lg" href="search-results.html">Search</a>
</div>

使用的脚本:

<script type="text/javascript">
 $(document).ready(function () {
 $("#CityName").autocomplete({
            source: function (request,response) {
                $.ajax({
                    url: "/Home/GetRecord",
                    type: "POST",
                    dataType: "json",
                    data: { prefix: request.term },
                    success: function (data) {
                        response($.map(data, function (item) {
                            return { label: item.Title, value: item.Title };
                        }))
                    }
                })
            },
        });
    });
</script>

参考

  <link rel="stylesheet" href="https://code.jquery.com/ui/1.12.0/themes/smoothness/jquery-ui.css" />
<script src="https://code.jquery.com/jquery-3.2.1.min.js"></script>
<script src="https://code.jquery.com/ui/1.12.0/jquery-ui.min.js"></script>

C#

 public JsonResult GetRecord(string prefix)
    {
        DataSet ds = PostRepo.GetName(prefix);
        List<search> searchlist = new List<search>();
        foreach (DataRow dr in ds.Tables[0].Rows)
        {
            searchlist.Add(new search
            {
               Title= dr["Title"].ToString(),
                Tags = dr["Tags"].ToString(),
                Id = dr["Id"].ToString()
            });
        }
        return Json(searchlist, JsonRequestBehavior.AllowGet);
    }

ViewBag.Title = "Home Page";如果没有收到错误消息但自动完成功能不起作用,我无法理解为什么它不起作用。请帮助我理解这个概念。

标签: c#asp.netasp.net-mvc-4autocomplete

解决方案


可能是您提到的检查布局页面脚本

并且不要在子视图中添加任何脚本,因为脚本可能与多个版本冲突

这是自动完成的工作示例


推荐阅读