我在代码隐藏中有这些数据并试图以各种格式将它传递给javascript函数:list of array,json string但无法通过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中传递此数组。请帮帮我
答案 0 :(得分:3)
您可以创建一个自定义类来表示Datatable。假设您的数据表有四列,请创建一个包含4个字段的自定义类。循环遍历数据表并将其转换为自定义类类型的对象数组。
最后,您可以使用以下代码将数组序列化为json。
JavaScriptSerializer js = new JavaScriptSerializer();
js.Serialize(data);
其中data是对象数组。
这是我使用的技术..
数据表无法直接序列化为JSON。参考What's the best way to jSON serialize a .NET DataTable in WCF?
答案 1 :(得分:1)
如果你想让它吐出实际的大括号字符,你必须在使用String.Format时转义(加倍)大括号。
示例:
string createArrayScript =
string.Format("var array2 = [{{0}},{{1}},{{2}},{{3}}];",
...
答案 2 :(得分:0)
尝试使用
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);
答案 3 :(得分:0)
答案 4 :(得分:0)
只需使用NewtonSoft Json并致电:
var JsonString = JsonConvert.SerializeObject(NameofDT, Formatting.Indented)