前台頁面
代碼如下:
$.ajax({
type: "post",
contentType: "application/json",
url: "../WebForm1.aspx/GetRightsStr",
dataType: "json",
success: function (msg) {
alert(msg.d);
var data = eval("(" + msg.d + ")");
$.each(data.rights, function (index, item) {
alert(item.RightsName);
});
},
error: function (e, s, d) {
alert(e);
alert(s);
alert(d);
}
});
後台方法:
代碼如下:
/// <summary>
/// DataTable轉成Json
/// </summary>
/// <param name="jsonName">josn名稱</param>
/// <param name="dt">要轉換的數據集</param>
/// <returns></returns>
public static string DataTableToJson(string jsonName, DataTable dt)
{
StringBuilder Json = new StringBuilder();
Json.Append("{\"" + jsonName + "\":[");
if (dt.Rows.Count > 0)
{
for (int i = 0; i < dt.Rows.Count; i++)
{
Json.Append("{");
for (int j = 0; j < dt.Columns.Count; j++)
{
Json.Append("\"" + dt.Columns[j].ColumnName.ToString() + "\":\"" + dt.Rows[i][j].ToString() + "\"");
if (j < dt.Columns.Count - 1)
{
Json.Append(",");
}
}
Json.Append("}");
if (i < dt.Rows.Count - 1)
{
Json.Append(",");
}
}
}
Json.Append("]}");
return Json.ToString();
}
這個方法是一個將DataTable轉換成字符串的方法 。今天遇到的問題是 在 var data = eval("(" + msg.d + ")");
出錯誤 提示 是 缺少 } 這個方法有用了很多次了 不知道為什麼出現這樣的錯誤 。
找了半天,才發現 是數據的問題 在返回的字符串裡 有 "\"這個字符, "\"具有轉義的作用
所有會出現這個錯誤,暈啊,真實害苦我了 ,希望大家不要像我這樣糊塗。