asp.net网络表单[WebMethod]

时间:2016-10-03 11:31:01

标签: asp.net web webforms json.net asp.net-ajax

当我使用List<Contract>

DB返回Json数据Entity Framework时,我的[WebMethod]出现问题
function populateData(pageIndex) {
                // populate data from database
                $.ajax({
                    url: "/Pages/App/Docs.aspx/PopulateDataByJquery",
                    data: "{pageNo: " + pageIndex + ", noOfRecord: 7}",
                    type: "POST",
                    dataType: "json",
                    contentType: "application/json; charset=utf-8",
                    success: OnSuccess,
                    error: onError
                });
            }
            function OnSuccess(data) {

                alert('good');
            }
            function onError() {
                alert('Failed!');
                $('#LoadingPanel').css('display', 'none');
            }

这是我的WeMethod。

[WebMethod]
    [ScriptMethod(ResponseFormat = ResponseFormat.Json)]
    public static List<Contract> PopulateDataByJquery(int pageNo, int noOfRecord)
    {
        System.Threading.Thread.Sleep(2000);
        Entities4 db = new Entities4();
        List<Contract> data = new List<Contract>();
        int skip = (pageNo - 1) * noOfRecord;
        data = db.Contracts.Include("PhysicalPerson").Include("Product").OrderBy(a => a.Id).Skip(skip).Take(noOfRecord).ToList(); 
        return data;
    }

我每次都得到ajax错误,请帮帮我!我不知道它是如何解决的。

1 个答案:

答案 0 :(得分:2)

您必须对ajax调用和WebMethod

进行一些更改
function populateData(pageIndex) {
                    // populate data from database
                    $.ajax({
                        url: "Docs.aspx/PopulateDataByJquery",
                        data: "{pageNo: pageIndex, noOfRecord: 7}",
                        type: "POST",
                        dataType: "json",
                        contentType: "application/json; charset=utf-8",
                        success: OnSuccess,
                        error: onError
                    });
                }
                function OnSuccess(data) {

                    alert('good');
                }
                function onError() {
                    alert('Failed!');
                    $('#LoadingPanel').css('display', 'none');
                }

更改WebMethod

    [WebMethod]
    public static string  PopulateDataByJquery(int pageNo, int noOfRecord)
    {
        System.Threading.Thread.Sleep(2000);
        Entities4 db = new Entities4();
        List<Contract> data = new List<Contract>();
        int skip = (pageNo - 1) * noOfRecord;
        data = db.Contracts.Include("PhysicalPerson").Include("Product").OrderBy(a => a.Id).Skip(skip).Take(noOfRecord).ToList(); 
        JavaScriptSerializer TheSerializer = new JavaScriptSerializer()
        var TheJson = TheSerializer.Serialize(data);
         // for this you need to add using System.Web.Script.Serialization;
        return TheJson;
    }

更多阅读this