我有一個通過回調方法的Jquery自動完成功能。但它似乎並沒有運行。無法執行JavaScript的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;
}
看來,自動完成功能是沒有得到所謂以及警報().. 有關如何調用它的任何建議?
新增: 檢查堆棧跟蹤後,它給了我一個錯誤
未知方法名GetNames
有什麼建議?
你可以在控制檯輸出返回的數據對象嗎?只是爲了確保回調成功被調用。 – rayfranco 2012-02-24 18:39:03
爲什麼在你把它們帶到這裏之前,你沒有打開javascript錯誤來查看錯誤? – Aristos 2012-02-24 18:47:48
@vini結合我們所有3個答案,_jk._表示您需要修復多個語法錯誤(其中一個是缺少的括號_Marcin Necsord Szulc_)。然後用一個名爲dataToSend的變量(或任何你想要它調用的)替換'data:'部分中的字符串文字。然後運行它,它應該繼續工作。 – rcplusplus 2012-02-24 18:53:22