我有一个ASP.NET 4.5 WebForm应用程序,我想在其中添加自动完成到文本框。 我正在调查jquery-ui,但我似乎无法使其工作。ASP.NET JQuery-UI自动完成不工作
我正在使用jquery 3.1.1和jquery-ui 1.12.1。这是我的aspx页面的头部分。
ASPX
<head runat="server">
<link href="//ajax.googleapis.com/ajax/libs/jqueryui/1.12.1/themes/smoothness/jquery-ui.css" rel="stylesheet" type="text/css" />
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/3.1.1/jquery.min.js"></script>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jqueryui/1.12.1/jquery-ui.min.js"></script>
<script type="text/javascript">
$(document).ready(function() {
$("#SearchDynamicTxt").autocomplete({
source: function (request, response) {
$.ajax({
type: "POST",
contentType: "application/json; charset=utf-8",
url: "UserReports.aspx/GetUsers",
data: "{'term':'" + $("#SearchDynamicTxt").val() + "'}",
dataType: "json",
success: function (data) {
response(data.d);
},
error: function (result) {
alert("Error");
}
});
}
});
});
</script>
</head>
这里是文本控件:
<asp:TextBox ID="SearchDynamicTxt" runat="server" OnTextChanged="SearchDynamicTxt_TextChanged" AutoPostBack="true" ></asp:TextBox>
这里是后面的代码:
[WebMethod]
public static string[] GetUsers(string term)
{
List<string> usersList= new List<string>();
string CS= ConfigurationManager.ConnectionStrings["UsersCS"].ConnectionString;
using (SqlConnection con = new SqlConnection(CS))
{
con.Open();
SqlCommand cmd = new SqlCommand("SELECT Name FROM Customers WHERE Name Like '" + term + "%'", con);
SqlDataReader reader = cmd.ExecuteReader();
while(reader.Read())
{
usersList.Add(reader[0].ToString());
}
}
return usersList.ToArray();
}
我敢肯定有东西,我忘了或拼写错误,但我不知道什么或在哪里。当我尝试在控件中写一些东西时,没有任何反应。我希望它向我展示一个可能的匹配用户列表,当我选择其中一个时,可以调用方法OnTextChanged。
更新!
现在,下拉列表显示出来了,我想选择一个用户和那个选择来触发OnChanged方法。目前这没有发生。我需要按回车或点击页面上的某个地方生成回传,然后检测OnChanged文本。我猜我需要改变这一点:
success: function (data)
{
response(data.d);
},
也许增加一个事件参数或什么?我目前正在寻找解决方案,但如果有人知道答案,直到我找到它,请分享它。
谢谢!
你需要在文本框中添加这些OnTextChanged =“SearchDynamicTxt_TextChanged”AutoPostBack =“true”? –