2

HttpHandler - .ashx ファイルで動作する Jquery オートコンプリートがあります。それは正常に動作します。コード ビハインドで [WebMethod] を使用してオートコンプリートを使用する簡単な方法があるのではないかと思っています。これには利点がありますか?

4

1 に答える 1

6

HttpHandler と Web サービスの両方の実装は同じように
動作しますが、軽量であるため HttpHandler を好みます
。一方、Web サービスは要求と応答の xml データをエンコードし、追加のペイロードを追加します。

Web メソッドによる POP JqueryUI オートコンプリート:
http://blog.nitinsawant.com/2011/09/integrating-jquery-ui-autocomplete-in.html

JS:

$(document).ready(function () {
            $("#<%=txtAutoComplete.ClientID %>").autocomplete({
                source: function (request, response) {
                    $.ajax({
                        url: "webservice/TestService.asmx/SearchData",
                        data: "{ 'q': '" + request.term + "', 'limit': '10' }",
                        dataType: "json",
                        type: "POST",
                        contentType: "application/json; charset=utf-8",
                        dataFilter: function (data) { return data; },
                        success: function (data) {
                            response($.map(data.d, function (item) {
                                return {
                                    label: item.Name,
                                    value: item.id + ""
                                }
                            }))
                        }
                    });
                }
            });
});


C#:

[System.Web.Services.WebMethodAttribute(),  System.Web.Script.Services.ScriptMethodAttribute()]
public List<tdata> SearchData(string q, int limit)
{
    return new List<tdata> { new tdata { id = 0, name = "nitin" } };
}
于 2012-06-12T07:16:27.327 に答える