【问题标题】:how to pass c# datatable to a javascript function如何将c#数据表传递给javascript函数
【发布时间】:2013-10-24 13:54:14
【问题描述】:

我在代码隐藏中有这些数据,并尝试以各种格式将其传递给 javascript 函数:列表数组、json 字符串,但无法通过 javascript var 对象获取数据。 这里最后的数据格式在后面的代码中:

    List<string>[] array2 = new List<string>[listLenght];
    array2.Initialize();

    for (int ii = 0; ii < listLenght; ii++)
    {
    array2[ii] = new List<string>();
       array2[ii].Add(Convert.ToString(dt.Rows[ii][5]));
       array2[ii].Add(Convert.ToString(dt.Rows[ii][9]));
       array2[ii].Add(Convert.ToString(dt.Rows[ii][10]));
       array2[ii].Add(Convert.ToString(dt.Rows[ii][11]));

    }

然后尝试用这种方式调用javascriot:

   string createArrayScript = string.Format("var array2 = [{0},{1},{2},{3}];",         string.Join(",",",",",", array2));

但返回错误:FormatException 未被用户代码处理 索引(从零开始)必须大于或等于零且小于主题列表的大小。

这是对函数的调用: Page.ClientScript.RegisterStartupScript(this.GetType(), "registerPoiArray", createArrayScript, true);

这里是 javascript var 格式:

    var markers = Poi;

        var markers = [
{
"title": "via Andria, Roma",
"lat": 41.8902643,
"lng": 12.6638589,
"description": "fdsad"
},
{
"title": "via canosa, Roma",
"lat": 41.8838417,
"lng": 12.5438227,
"description": "fdsad"
},
{
"title": "via taranto, Milano",
"lat": 45.4383343,
"lng": 9.1505354,
"description": "fdsad"
},
{
"title": "via barletta, Roma",
"lat": 41.9102707,
"lng": 12.4580826,
"description": "fdsad"
}];

我不能在 javascript 中传递这个数组。请帮帮我

【问题讨论】:

  • 将你的数据表序列化为 Json

标签: c# javascript asp.net json google-maps


【解决方案1】:

您可以创建一个自定义类来表示数据表。假设您的数据表有四列,请创建一个包含 4 个字段的自定义类。循环遍历数据表并将其转换为自定义类类型的对象数组。

最后你可以使用以下代码将数组序列化为json。

JavaScriptSerializer js = new JavaScriptSerializer();
js.Serialize(data);

其中 data 是对象数组。

这是我使用的技术..

数据表无法直接序列化为 JSON。参考What's the best way to jSON serialize a .NET DataTable in WCF?

【讨论】:

    【解决方案2】:

    如果您希望它吐出实际的大括号字符,则在使用 String.Format 时必须转义(加倍)大括号。

    例子:

    string createArrayScript = 
         string.Format("var array2 = [{{0}},{{1}},{{2}},{{3}}];",
         ...
    

    【讨论】:

      【解决方案3】:

      尝试使用

      System.Web.Helpers.Json.Encode
      

      并改变你得到的结构。

      List<object> toEncode=new List<object>();
      foreach (DataRow dr in dt.Rows){
         Dictionary<string,string> element=new Dictionary<string,string>();
         element.Add("title",dr["title"] as string);
         //repeat for all neaded colums
         toEncode.Add(element);
      }
      string jsonString=Json.Encode(toEncode);
      

      【讨论】:

        【解决方案4】:

        我在放置解决方案时创建了gist

        我希望这对你有用...

        问候,

        【讨论】:

          【解决方案5】:

          只需使用 NewtonSoft Json 并调用:

          var JsonString = JsonConvert.SerializeObject(NameofDT, Formatting.Indented)
          

          【讨论】:

            猜你喜欢
            • 1970-01-01
            • 1970-01-01
            • 2019-12-13
            • 2023-02-25
            • 1970-01-01
            • 2019-08-07
            • 1970-01-01
            • 1970-01-01
            • 2017-08-12
            相关资源
            最近更新 更多