0

我在 asp.net 项目中有一个 webmethod 我想在 jquery ajax 方法中传递一个 listview 但我现在不知道如何检测 listview 的元素并使用它们。以下代码是我的 c# 代码。bt 我需要 jquery 代码

if (ck != null)
{
      reqnum[0, 0] = "@RequestingBranchID";
      reqnum[0, 1] = ck["BranchID"];
      reqnum[1, 0] = "@ProviderBranchID";
      reqnum[1, 1] = customer.ToString();
      DataTable dt = SqlCommands.FillData(out OutStatus, out OutMessage, "BSD.SW_Boxes_StockOfProviderAndRequestingBranch", CommandType.StoredProcedure, reqnum);
      List<DataRow> rows = dt.Rows.Cast<DataRow>().ToList();
      int x=rows.Count;
      return rows;
}
4

2 回答 2

0

好的,假设您有一个DataTable,并且您想将其结果传递DataTable给一些 JavaScript 以使用Ajax. 所以第一步是我们需要将这些结果转换成JSON格式。你可以通过以下方法::

public string GetJson(DataTable dt)
{
    System.Web.Script.Serialization.JavaScriptSerializer serializer = new System.Web.Script.Serialization.JavaScriptSerializer();
    List<Dictionary<string, object>> rows = new List<Dictionary<string, object>>();
    Dictionary<string, object> row = null;

    foreach (DataRow dr in dt.Rows) {
        row = new Dictionary<string, object>();
        foreach (DataColumn col in dt.Columns) {
            row.Add(col.ColumnName, dr[col]);
        }
        rows.Add(row);
    }
    return serializer.Serialize(rows);
}

下一步是在 JavaScript 中解析结果JSON字符串,我想这是最简单的部分。您可以检查此问题以了解如何将JSON字符串解析为对象安全地将 JSON 字符串转换为对象。如果您想了解更多信息,请告诉我。

于 2013-02-18T11:26:37.380 回答
0

您可以使用JSON.NET将数据表序列化为 JSON。然后使用 ajax 调用 web 方法。

在服务器端,

[WebMethod]
[ScriptMethod(ResponseFormat = ResponseFormat.Json)]
public static string GetList(int branchID, string customer)
{
    // do your code here
    reqnum[0, 0] = "@RequestingBranchID";
    reqnum[0, 1] = branchID;
    reqnum[1, 0] = "@ProviderBranchID";
    reqnum[1, 1] = customer;
    DataTable dt = SqlCommands.FillData(out OutStatus, out OutMessage, "BSD.SW_Boxes_StockOfProviderAndRequestingBranch", CommandType.StoredProcedure, reqnum);
    if(dt!=null)
    {
          return Newtonsoft.Json.JsonConvert.SerializeObject(dt);
    }
    else{
        //return "[]"; 
    }
}

然后在脚本中调用您的方法并传递该方法的参数。

$(function(){});
    $('#myButton').click(function() {
        $.ajax({ 
            type: "POST",
            url: "YourPage.aspx/GetList",
            data: "{'branchID':" + branchID + ",'customer':" + customer + "}",
            contentType: "application/json; charset=utf-8",
            dataType: "json",
            success: function (data) {
                var jsonResult = $.parseJSON(data.d);
                // do your client side code here
            }
        });
    });
});

注意:如果您没有使用 web 服务/在代码中编写方法,请[ScriptService]在您的类之前使用装饰器并包含以下命名空间。

using System.Web.Script.Services;
using System.Web.Services;
于 2013-02-18T11:33:49.280 回答