【发布时间】:2019-07-04 05:18:03
【问题描述】:
我是 asp.net 的初学者,我正在尝试添加具有自动完成功能的搜索栏。
我希望结果返回一个对象列表,两个表上的存储过程的结果,每个表有超过 200.000 行(自动完成的前 30 个结果),有 2 个字段:标签 (Resultat) 和 Id ( IdRes)。
我设法调用了我的函数,我得到了结果,但自动完成弹出窗口没有显示或以错误的方式显示。
这是我_layout.cshtml的代码:
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>@ViewBag.Title - CLAP : le colloque du cinéma</title>
@Styles.Render("~/Content/css")
@Scripts.Render("~/bundles/modernizr")
@Scripts.Render("~/bundles/jquery")
@Scripts.Render("~/bundles/bootstrap")
@Scripts.Render("~/bundles/jqueryval")
@Scripts.Render("~/bundles/jqueryui")
<link href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.11.1/themes/smoothness/jquery-ui.css" rel="stylesheet" />
<script src="Scripts/jquery-3.3.1.min.js"></script>
<script src="http://ajax.googleapis.com/ajax/libs/jqueryui/1.11.1/jquery-ui.min.js"></script>
<script type="text/javascript">
$(document).ready(function () {
$("#navinput").autocomplete({
source: function (request, response) {
$.ajax({
type: "POST",
contentType: "application/json; charset=utf-8",
url: "Home/RechercheAutoComplete",
data: "{'term':'" + $("#navinput").val() + "'}",
datatype: "json",
success: function (data) {
response($.map(data, function (value, key) {
return {
label: value.Resulat,
value: value.Resulat
}
}));
},
error: function (result) {
alert("Error");
}
});
}
});
});
</script>
</head>
<body>
<div class="navbar navbar-inverse navbar-fixed-top">
<div class="container">
<div class="navbar-collapse collapse">
...
<div class="navbar-form navbar-left" role="search">
<div class="formgroup">
<input class="form-control" id="navinput" name="navinput" runat="server" type="text" width="512" placeholder="Search..." />
<button class="btn btn-default glyphicon glyphicon-search" id="navsearchbtn" runat="server" OnClick="navSearch" type="submit" />
</div>
</div>
...
</div>
</div>
</div>
<div class="container body-content">
@RenderBody()
</div>
<div class="footer">
<p>© @DateTime.Now.Year - CLAP</p>
</div>
@RenderSection("scripts", required: false)
</body>
</html>
因此,使用此代码,它会在浏览器的左上角显示一个弹出菜单,而不是在我的文本框下方,它会显示 ResId 而不是 Resultat。
我做错了什么,我该如何解决?我希望用户选择一个标签但返回 ID。
【问题讨论】: