11

如何获取数据表中的列数?

我可以通过执行 oTable.fnGetData().length 来获取行数,但是如何获取列数以便可以像这样遍历每个单元格:

var numColumns = //How to get the number of columns?
    for(var r=0;r<oTable.fnGetData().length;r++){
        for(var c=0;c <= numColumns;c++){
            console.log("[R]: "+r+ "[C]: "+c+ " data: "+oTable.fnGetData(r,c));   
        }
    }
4

2 回答 2

15

获取列数

  • 数据表 1.9+

    // Get number of all columns
    var numCols = $('#example').dataTable().fnSettings().aoColumns.length;
    
    // Get number of visible columns
    var numCols = $('#example thead th').length;
    

    请参阅此 jsFiddle进行演示。

  • 数据表 1.10+

    // Get number of all columns
    var numCols = $('#example').DataTable().columns().nodes().length;
    
    // Get number of visible columns
    var numCols = $('#example').DataTable().columns(':visible').nodes().length;
    
    // Get number of visible columns (alternative way)
    var numCols = $('#example thead th').length;
    

    请参阅此 jsFiddle进行演示。

迭代每个单元格

  • 数据表 1.10.6+

    $('#example').DataTable().cells().every( function (rowIndex, colIndex) {
        var data = this.data();
    
        console.log("Row:", rowIndex, "Col:", colIndex, "Data:", data);
    });
    
于 2015-10-01T14:12:11.263 回答
8

fnGetData 可用于获取单个数据行。因此,您可以简单地检查数据行的长度以了解列数。

例子:

oTable.fnGetData(someRowNumber).length;

以上将返回该数据行中的列数。

于 2012-05-30T01:17:08.610 回答