微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

jquery – Ajax数据源(对象):TypeError:f未定义

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

如jquery DataTables的官方网站所述,返回的JSON响应似乎很好
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',"url":"index.aspx/Risky","dataSrc": function (json) {
           return $.parseJSON(json.d);
        }
    },{ "data": "Risk_Category" }
    ]
});

有关此错误和其他常见控制台错误的详细信息,请参阅jQuery DataTables: Common JavaScript console errors.

原文地址:https://www.jb51.cc/jquery/176671.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐