我不知道自己缺少什么或代码有什么问题,我已经尝试从控制台进行跟踪,但是TransmittedDataTable.on('draw'不起作用。我的代码有什么问题?

JavaScript代码:

    $(document).ready(function () {
GetData()
});

function GetData() {
        var TransmittedDataTable = $('#tbtransmitteddata').dataTable({
            autoWidth: true,
            initComplete: function () {
                //this.api().columns([0, 1, 2, 3, 4]).every(function () {
                this.api().columns().every(function () {
                    var column = this;

                    var select = $('<select><option value=""></option></select>')
                .appendTo($(column.footer()).empty())
                .on('change', function () {
                    var val = $.fn.dataTable.util.escapeRegex(
                        $(this).val()
                    );

                    column
                        .search(val ? '^' + val + '$' : '', true, false)
                        .draw(function () {

                        });
                });
                    column.data().unique().sort().each(function (d, j) {
                        select.append('<option value="' + d + '">' + d + '</option>')
                    });
                });
            },
            'drawCallback': function (settings) {
                //var api = this.api();
                // Output the data for the visible rows to the browser's console
                //console.log(api.rows({ page: 'current' }).data());
            },
            processing: true,
            ajax: {
                type: 'post',
                contentType: 'application/json; charset=utf-8',
                url: '../Application/ApplicationWS.asmx/GetDepEdTransmittal2',
                dataSrc: function (json) {
                    return JSON.parse(json.d);
                }
            },
            columns: [
                { data: "Region" },
                { data: "Division" },
                { data: "Station" },
                { data: "EmployeeNumber" },
                { data: "EmployeeName" },
                { data: "DednCode" },
                { data: "PolicyNo" },
                { data: "EffectDate" },
                { data: "TermDate" },
                { data: "Amount" },
                { data: "LoanAmount" },
                { data: "InterestAmount" },
                { data: "OtherCharges" },
                { data: "BillingType" },
                { data: "UpdateCode" }
            ],
            //deferLoading: 57,
            'columnDefs': [
            { 'targets': 4, 'title': 'Employee Name' },
            { 'targets': 5, 'title': 'Deduction Code' },
            { 'targets': 7, 'title': 'Effectivity Date' },
            { 'targets': 8, 'title': 'Termination Date' },
            { 'targets': 9, 'title': 'Deduction Amount' },
            { 'targets': 10, 'title': 'Loan Amount' },
            { 'targets': 11, 'title': 'Interest Amount' },
            { 'targets': 12, 'title': 'Other Charges' },
            { 'targets': 13, 'title': 'Billing Type' },
            { 'targets': 14, 'title': 'Update Code' }
            //{ "targets": [13], "visible": false, "searchable": false }
            ]
            //,scrollY:'50vh',
            , dom: 'Blfrtip'
            , colReorder: true
            , buttons: [{
                extend: 'pdfHtml5',
                download: 'open',
                orientation: 'landscape',
                pageSize: 'LEGAL',
                title: 'BILLING LIST & PROMISORRY NOTES',
                //message: 'BILLING LIST & PROMISORRY NOTES',
                exportOptions: {
                    //columns: [0, 1, 2, 3, 4, 5]
                },
                customize: function (doc) {
                    doc.content.splice(0, 0, {
                        margin: [0, 0, 0, 10],
                        alignment: 'center',
                        image: ''
                    });

                    //console.log(doc.content[2]);

                    //doc.content[2].table.widths = [40, 40, 40, 60, 100, 40];
                }
            }]
        });
         TransmittedDataTable.on('draw.dt', function () {
            TransmittedDataTable.columns().indexes().each(function (idx) {
                var select = $(TransmittedDataTable.column(idx).footer()).find('select');

                if (select.val() === '') {
                    select
                      .empty()
                      .append('<option value=""/>');

                    TransmittedDataTable.column(idx, { search: 'applied' }).data().unique().sort().each(function (d, j) {
                        select.append('<option value="' + d + '">' + d + '</option>');
                    });
                }
            });
        });


}

我已经更新了代码,尝试了draw.dt,但是出现了新错误,在浏览器控制台中,错误显示Uncaught TypeError: TransmittedDataTable.columns is not a function(…)

最佳答案

如果您已使用jQuery对象或使用.dt初始化了表,则应在事件名称中添加dataTable(),请参见下面的示例。

TransmittedDataTable.on('draw.dt', function(){

});


如果使用DataTable()初始化表,则不需要.dt后缀。

由于您尝试使用TransmittedDataTable变量访问其他API方法,因此请使用DataTable()初始化表,一切将按预期进行。

有关更多信息,请参见Events

10-06 00:32