首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >来自服务器端的DataTables可单击行链接

来自服务器端的DataTables可单击行链接
EN

Stack Overflow用户
提问于 2016-11-28 19:00:21
回答 2查看 1.4K关注 0票数 0

我有一个datatable,在这里我同时加载了所有数据,但是我的数据集最终会变得非常大,所以我决定移动所有服务器端。

以前,我可以通过使用"data-url“属性将链接嵌入到每一行中,然后使用此函数侦听单击:

代码语言:javascript
复制
$('#table tbody').on('click', 'tr', function () {
        var url = this.getAttribute("data-url")
        window.open(url, "_self");
    });

它完全是这样工作的,但是我还没有弄清楚如何使用AJAX和JSON来完成这个任务。

我的JSON响应如下:

代码语言:javascript
复制
 {"recordsFiltered": 1, "recordsTotal": 6, 
 "data": [{"4": "", "6": "", "7": "Online", "3": "", "DT_RowClass": "success",
 "5": "", "data-url": "/relative-url/pk/", "2": "TestType2", 
 "0": "Test", "1": "ABCD"}], "draw": "11"}

但是,我不确定如何让DataTables将data-url属性添加到行中。我一直在浏览文档,试图找到这个用例的示例,但到目前为止还没有找到任何运气。

如果没有内置的功能,我想我将需要覆盖DataTables用于加载JSON数据的函数,但我不知道如何做到这一点。

我的服务器端语言比javascript好得多,所以如果可能的话,我真的很欣赏更具体的答案。

谢谢

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2016-11-28 19:20:28

正如上面@cjungel所指出的那样,这是一种方法。不过,Mor最新版本的DataTable使用rowCallback。例如,您可以使用这种类型的东西:

代码语言:javascript
复制
"rowCallback": function(row, data, index){
    $(row).attr("data-url", data[1]);
}

根据这个JSFiddle。希望这能有所帮助。

票数 2
EN

Stack Overflow用户

发布于 2016-11-28 19:15:59

您可以使用fnCreatedRow回调。

根据文档

当创建TR元素(并且插入了所有TD子元素)时调用此函数,如果使用DOM源,则调用该函数,从而允许对TR元素的操作(添加类等)。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/40851555

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档