从数据表中的变量设置bPortal时出现问题

Issue with setting bSortable from a variable in datatables

本文关键字:问题 bPortal 设置 数据表 变量      更新时间:2023-09-26

我正试图通过使用php中的datatables插件来实现特定列的隐藏排序选项。如果我写下面的代码,那么它就可以工作了:"aoColumns":[{'bSortable':false},null,null

但我需要动态,这就是为什么我使用一个变量及其值(对于{'bSortable': false},null,null,null,null,null,null,null,null,null,null,null,null,null,{'bSortable': false},我将其存储在一个名为excluded_clmns_sorting的js变量中)。即使我试图打印excluded_clmns_sorting的值,它也显示{'bSortable': false},null,null,null,null,null,null,null,null,null,null,null,null,null,{'bSortable': false}。然后我像"aoColumns" : [excluded_clmns_sorting],一样编码,但它在控制台中显示错误。错误为"TypeError:oCol is undefined"。所以请告诉我问题出在哪里。

提前谢谢。

我怀疑您的问题是将字符串分配给excluded_clmns_sorting。但是,在信息如此之少的情况下,很难确定。如果是这种情况,则需要在将字符串传递给数据表之前对其进行JSON.parse。Datatables需要aoColumns的数组。

这两项工作中的任何一项:

$(document).ready(function() {
    var excluded_clmns_sorting = JSON.parse('[{"bSortable": false},  null, null,  null, {"bSortable" : false}]');
    //var excluded_clmns_sorting = [{"bSortable": false},  null, null,  null, {"bSortable" : false}];
    $('#example').dataTable({
        "sPaginationType": "full_numbers",
        "aoColumns": excluded_clmns_sorting
    });
});

http://jsfiddle.net/ave8q/