gpt4 book ai didi

jquery - Ajax数据源(对象):TypeError: f is undefined

转载 作者:行者123 更新时间:2023-12-03 22:45:05 24 4
gpt4 key购买 nike

我正在开发我的 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>

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" }]
});

这是我的 Web 方法,我正在调用它来获取对象列表的 JSON 响应

 [WebMethod]
[ScriptMethod]
public static string Risky()
{
return JsonConvert.SerializeObject(riskList);
}

来自服务器的 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"}]

返回的 JSON 响应对我来说似乎很好,如 jquery DataTables 官方网站中所述 http://www.datatables.net/examples/ajax/objects.html

但是表中没有填充任何数据,我在 Firebug 控制台中收到以下错误

TypeError: f is undefined

最佳答案

默认情况下,jQuery DataTables 需要以下格式的 Ajax 源数据。

{ 
"data": [

]
}

如果数据格式不同,则需要使用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" }
]
});

参见jQuery DataTables: Common JavaScript console errors有关此错误和其他常见控制台错误的更多信息。

关于jquery - Ajax数据源(对象):TypeError: f is undefined,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33649699/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com