jQuery UI V10 Autocomplete で動作するテスト ベッドを取得しようとしています。デモ プログラムは動作していますが、コードを C# と ASP.NET Web サービスを使用する例に適合させると、ステータス 200 parseerror が発生します。jSon データは、二重引用符で囲まれて返されます。応答を jsonLint に入れると、外側の引用符を削除すると検証されます。「d」も付いています。ASP Web サービスに期待するプレフィックス。
有効な JSON を返す応答を取得するにはどうすればよいですか?
jQuery コード:
$(settings.selector).autocomplete({
source: function (request, response) {
var data = JSON.stringify({
prefixText: request.term,
count: settings.count
});
ajaxCall(settings.url, data, {
onSuccess: function (data) {
var matches = [];
$.each(data, function (item) {
matches.push({
label: data[item].label,
value: data[item].value,
id: data[item].id
});
});
response(matches);
}
});
},
minLength: settings.minLength,
change: function (event, ui) {
if (ui && ui !== null && ui.item && ui.item !== null) {
currentValue = ui.item.label;
if (settings.onChange && settings.onChange !== null) {
settings.onChange(ui.item, settings.selector, oldValue);
}
} else {
$(settings.selector).val(oldValue);
}
},
select: function (event, ui) {
currentValue = ui.item.label;
if (settings.onSelect && settings.onSelect !== null) {
settings.onSelect(ui.item, settings.selector, oldValue);
}
},
open: function () {
$(this).removeClass("ui-corner-all").addClass("ui-corner-top");
},
close: function () {
$(this).removeClass("ui-corner-top").addClass("ui-corner-all");
}
});
Web サービス コード:
[WebService(Namespace = "http://tempuri.org/")]
[WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
[System.ComponentModel.ToolboxItem(false)]
[System.Web.Script.Services.ScriptService]
public class TestAutocomplete : System.Web.Services.WebService
{
[WebMethod(BufferResponse = true, Description = "Lookup City")]
[ScriptMethod(ResponseFormat = ResponseFormat.Json)]
public string CityList(string prefixText, int count)
{
List<AutoSuggestReturn> matches = AssessorBusinessLayer.City.List(prefixText, count);
Messages.ConsoleLog(string.Format("Prefix: {0} return {1} matches", prefixText, matches.Count));
string ret = AutoSuggestReturn.ConvertToJson(matches);
return ret;
}
}
Web サービス呼び出しから返された xhr オブジェクト:
xhr: Object
abort: function ( statusText ) {
always: function () {
complete: function () {
done: function () {
error: function () {
fail: function () {
getAllResponseHeaders: function () {
getResponseHeader: function ( key ) {
overrideMimeType: function ( type ) {
pipe: function ( /* fnDone, fnFail, fnProgress */ ) {
progress: function () {
promise: function ( obj ) {
readyState: 4
responseText: "{"d":"[{\"id\":\"10499\",\"label\":\"Delmar,AL (35551)\",\"value\":\"Delmar,AL (35551)\"},{\"id\":\"2679\",\"label\":\"Delmar,DE (19940)\",\"value\":\"Delmar,DE (19940)\"},{\"id\":\"2401\",\"label\":\"Delmar,IA (52037)\",\"value\":\"Delmar,IA (52037)\"},{\"id\":\"2679\",\"label\":\"Delmar,MD (21875)\",\"value\":\"Delmar,MD (21875)\"},{\"id\":\"3584\",\"label\":\"Delmar,NY (12054)\",\"value\":\"Delmar,NY (12054)\"},{\"id\":\"4780\",\"label\":\"Delmita,TX (78536)\",\"value\":\"Delmita,TX (78536)\"},{\"id\":\"3352\",\"label\":\"Delmont,NJ (08314)\",\"value\":\"Delmont,NJ (08314)\"},{\"id\":\"11550\",\"label\":\"Delmont,PA (15626)\",\"value\":\"Delmont,PA (15626)\"},{\"id\":\"4574\",\"label\":\"Delmont,SD (57330)\",\"value\":\"Delmont,SD (57330)\"}]"}"
setRequestHeader: function ( name, value ) {
state: function () {
status: 200
statusCode: function ( map ) {
statusText: "OK"