如何使用数据填充/显示添加的数据表行?

时间:2016-07-06 16:43:55

标签: javascript jquery asp.net gridview datatables

我正在使用datatables.net插件执行一些ASP.NET gridview转换。我为什么这样做的答案更复杂,可以辩论。但是,我需要帮助解决我遇到的其中一个问题。

使用Javascript转换页面上的gridview实际上非常简单并且运行良好。主要问题是我希望在数据表的主体内有一个固定的“总”行(页脚),以便它像表格的其余部分一样保持响应。

我试图使用代码隐藏添加页脚,我可以使用总数据填充该页脚,但它不能响应表的其余部分。我假设是因为<tfoot>超出了<tbody>

使用javascript,我已经成功添加了一个新的数据表行,我可以将数据输出到控制台,但是我无法使用对象数据填充添加的行。

使用Javascript:

var sum;
$(document).ready(function () {
var table = $('#cphPage_gvTaxColl').DataTable();

//convert string to int
var intVal = function (i) {
    var j = $("<span/>");
    var txt = j.html(i).text();

    //        alert('txt :' + txt);

    var myVal = typeof txt === 'string' ?
        parseFloat(txt.replace(/[^\d.-]/g, '')) :
        typeof txt === 'number' ?
            i : 0;
    return myVal || 0;
};

//format integer as currency
var formatSum = function (myVal) {
    return accounting.formatMoney(myVal, {
        symbol: "$",
        precision: 2,
        thousand: ",",
        decimal: ".",
        format: {
            pos: "%s %v",
            neg: "%s (%v)",
            zero: "%s  0.00"
        }
    });
};

//add total row and determine index
table.row.add(['GRAND TOTAL']).draw();
var total_row = (table.row().count() + 1);
var total_col = (table.row(total_row).column().count + 1);

//alert
console.log('total row: ' + total_row);

//loop columns
table.columns('.sum').every(function () {
    sum = this
        .data()
        .reduce(function (a, b) {
            console.log('adding ' + intVal(a) + ' and ' + intVal(b));
            return intVal(a) + intVal(b);
        });

    //alert
    console.log('sum: ' + sum);

    console.log('column row 2 val: ' + this.data().row([2]));

    $(this.cell.node( total_row )).html(
                formatSum(sum)
            );

});
});

如何在数据行中显示对象数据?

我也收到以下错误消息,我不确定哪个参数丢失(第2列和第3列为空):

Error message

我在控制台数据中包含了一个屏幕截图,如果需要,我可以提供.aspx标记:

Page + cosole log output

我还在学习这些东西的细节。非常感谢您提供的任何指导。

提前致谢!

1 个答案:

答案 0 :(得分:0)

这是我的解决方案:

  1. datatables的html表格应为<tfoot>
  2. 这样的事情:

    <table id='table'>
        <tbody>
            <tr><td></td></tr>
        </tbody>
        <tfoot>
            <tr><td></td></tr>
        </tfoot>
    </table>
    
    1. 定义footerCallback字段
    2. Datatables初始化:

      $('#table').dataTable({
      ...
        "footerCallback": _footerDrawn
      ...
      });
      
      1. footerCallback
      2. 我使用服务器端数据,因此我的页脚数据源只是 ajax-response 的另一个字段:

        _footerDrawn: function( row, data, start, end, display ) {
          var table = $('#table').dataTables();
          var json = table.api().ajax.json();
            // assign values to each cell of the footer from json.total array
            $.each( table.api().columns().indexes(), function( index ) {
              $( table.api().column( index ).footer() ).html( json.total[index] );
            });
          }
        }
        

        json.total包含要在footer

        中打印的字符串数组