ume*_*mer 6 asp.net jquery json datatables webmethod
我正在开发我的ASP.Net Web应用程序,我必须使用Ajax数据源填充HTML表,我正在使用jQuery DataTables插件.
HTML代码:
<table class="table table-striped table-hover table-bordered display" id="example" cellspacing="0" width="100%">
<thead>
<tr>
<th>Prctice Group Risk No
</th>
<th>Practice_Group
</th>
<th>Risk_Category
</th>
</tr>
</thead>
</table>
Run Code Online (Sandbox Code Playgroud)
JavaScript代码:
$('#example').DataTable({
"ajax": {
"dataType": 'json',
"contentType": "application/json; charset=utf-8",
"type": "POST",
"url":"index.aspx/Risky"
},
"columns": [
{ "data": "Prctice_Group_Risk_No" },
{ "data": "Practice_Group" },
{ "data": "Risk_Category" }]
});
Run Code Online (Sandbox Code Playgroud)
这是我的Web方法我正在调用获取对象列表的JSON响应
[WebMethod]
[ScriptMethod]
public static string Risky()
{
return JsonConvert.SerializeObject(riskList);
}
Run Code Online (Sandbox Code Playgroud)
来自服务器的JSON响应:
d:"[{"Prctice_Group_Risk_No":1,"Practice_Group":"M&A","Risk_Category":"Conflicts of Interests"},{"Prctice_Group_Risk_No":2,"Practice_Group":"abc","Risk_Category":"Client Care and Communication"}]
Run Code Online (Sandbox Code Playgroud)
Jquery DataTables官方网站http://www.datatables.net/examples/ajax/objects.html中描述的JSON响应对我来说似乎很好 .
但是表中没有填充任何数据,我在Firebug控制台中收到以下错误
TypeError:f未定义
Gyr*_*com 15
默认情况下,jQuery DataTables以下列格式预期Ajax源数据.
{
"data": [
]
}
Run Code Online (Sandbox Code Playgroud)
如果数据格式不同,则需要使用ajax.dataSrc
为表数据定义数据属性(d
在您的示例中).
我不是ASP.NET专家,但似乎你用JSON格式对数据进行两次编码.
对于当前的服务器端代码,请尝试以下JavaScript代码:
$('#example').DataTable({
"ajax": {
"dataType": 'json',
"contentType": "application/json; charset=utf-8",
"type": "POST",
"url":"index.aspx/Risky",
"dataSrc": function (json) {
return $.parseJSON(json.d);
}
},
"columns": [
{ "data": "Prctice_Group_Risk_No" },
{ "data": "Practice_Group" },
{ "data": "Risk_Category" }
]
});
Run Code Online (Sandbox Code Playgroud)
有关此错误和其他常见控制台错误的详细信息,请参阅jQuery DataTables:常见JavaScript控制台错误.