【发布时间】:2012-03-15 05:17:36
【问题描述】:
我有一个通过回调方法实现的 Jquery 自动完成功能。但是它似乎没有运行。
这是我的代码:
在客户端:
<script type="text/javascript">
$(document).ready(function() {
alert("hi");
$("#Text1").autocomplete({
minLength: 0,
source: function (request, response) {
$.ajax({
type: "POST",
contentType: "application/json; charset=utf-8",
url: 'BlissMaker.aspx/GetNames',
data: "{ 'sname':'" + request.term + "' }",
dataType: "json",
dataFilter: function (data) { return data; },
success: function (data) {
if (data.d != null) {
response($.map(data.d, function (item) {
return {
label: item.Name,
value: item.Id
}
}))
}
},
error: function (XMLHttpRequest, textStatus, errorThrown) {
alert(XMLHttpRequest.responseText);
}
});
},
focus: function (event, ui) {
$("#Text1").val(ui.item.label);
return false;
}
})
.data("autocomplete")._renderItem = function (ul, item) {
return $("<li></li>")
.data("item.autocomplete", item)
.append("<a><img src='" + item.icon + "' width='32' height='32' /> " + item.Name + "</a>")
.appendTo(ul);
};
}
</script>
在代码隐藏处:
[WebMethod(EnableSession = true)]
[ScriptMethod(ResponseFormat = ResponseFormat.Json)]
public List<States> GetNames(string sname)
{
List<States> sbStates = new List<States>();
con = new SqlConnection("Data Source=PRATEEK\\SQLEXPRESS;Initial Catalog=BD;Integrated Security=True;Pooling=False");
con.Open();
Me mee = (Me)Session["Me"];
qr = "SELECT FBFriends.FB_Id2, ActiveInfo.Name, ActiveInfo.Profile_Pic, ActiveInfo.Gender FROM [FBFriends],[ActiveInfo] WHERE FBFriends.FB_Id1='" + mee.Id + "' AND ActiveInfo.FB_Id=FBFriends.FB_Id2";
ds = new DataSet(qr);
da = new SqlDataAdapter(qr, con);
da.Fill(ds);
ds.Tables[0].Select(ds.Tables[0].Columns[1].ColumnName + " Like '%" + sname + "%' and " + ds.Tables[0].Columns[3].ColumnName + " = 'Female'");
foreach (DataRow row in ds.Tables[0].Rows)
{
States st = new States();
st.Id = row.ItemArray[0].ToString();
st.Name = row.ItemArray[1].ToString();
st.Value = row.ItemArray[1].ToString();
st.Icon = row.ItemArray[2].ToString();
sbStates.Add(st);
}
return sbStates;
}
似乎自动完成功能没有像 Alert() 一样被调用。 关于如何调用它的任何建议?
添加: 检查堆栈跟踪后,它给了我一个错误
未知方法名称 GetNames
有什么建议吗?
【问题讨论】:
-
可以在控制台输出返回的数据对象吗?只是为了确保回调成功被调用。
-
为什么你不打开 javascript 错误来查看错误,然后再把它们带到这里?
-
@vini 结合我们所有 3 个答案,jk. 表示存在多个语法错误(其中一个是缺少括号 Marcin Necsord Szulc提出)你需要修复。然后将
data:部分中的字符串文字替换为名为dataToSend的变量(或任何您希望调用的变量)。然后运行它,它应该在这一切之后工作。 -
对不起,它不起作用。我相信我的回调没有被调用。我跟踪但给出了未知的方法 GetNames
标签: javascript jquery asp.net jquery-ui autocomplete