如何将 C# 数据表传递给 JavaScript 函数
how to pass c# datatable to a javascript function
我在代码隐藏中拥有这些数据,并尝试将其传递给各种格式的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]));
}
然后尝试以这种方式调用javascript:
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 中传递这个数组。
您可以创建自定义类来表示数据表。假设您的数据表有四列,请创建一个包含 4 个字段的自定义类。循环访问数据表并将其转换为自定义类类型的对象数组。
最后,您可以使用以下代码将数组序列化为 json。
JavaScriptSerializer js = new JavaScriptSerializer();
js.Serialize(data);
其中数据是对象的数组。
这是我使用的技术。
数据表不能轻易地直接序列化为 JSON。 请参阅 jSON 在 WCF 中序列化 .NET 数据表的最佳方法是什么?
使用 String.Format 时,如果您希望它吐出实际的大括号字符,则必须对大括号进行转义(双倍)。
例:
string createArrayScript =
string.Format("var array2 = [{{0}},{{1}},{{2}},{{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);
我在
放置解决方案时创建了一个要点。
我希望这对你有用...
问候
只需使用 NewtonSoft Json 并调用:
var JsonString = JsonConvert.SerializeObject(NameofDT, Formatting.Indented)
相关文章:
- 创建一个类似链接的按钮,并通过Javascript函数打开一个新的弹出窗口
- 正在全局范围中查找JavaScript函数
- 如何将输入(type=text)从html表单传递到javascript函数
- 如何调用这个匿名 JavaScript 函数
- 通过Ajax将JavaScript函数传递给PHP文件
- 在javascript函数中设置全局变量
- 如何在执行此特定onclick事件时执行JavaScript函数
- 使用javascript函数在页面初始化后加载jquery
- javascript函数同步
- 如何将一个JavaScript函数回调为多个函数
- 在javascript函数中使用php变量
- 代码背后调用一个JavaScript函数的按钮点击-C#
- 将JavaScript函数与HTML分离
- 组合两个javascript函数
- 在 Java 中的 JavaScript 函数中插入 Wicket 值
- javascript函数内部的代码用逗号而不是分号分隔
- href属性内的javascript函数
- 使用html表单中的参数调用JavaScript函数
- 分析Javascript函数中的多个对象
- javascript函数的:和=之间的区别