2016-11-28 4 views
1

Ich weiß nicht, was ich vermisse oder was ist falsch mit meinem Code, ich habe bereits versucht, es von der Konsole zu verfolgen, aber die TransmittedDataTable.on('draw' funktioniert nicht. Was ist falsch an meinem Code?DataTables zeichnen nicht funktioniert

Javascript-Code:

$(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>'); 
        }); 
       } 
      }); 
     }); 

}

ich meinen Code bereits aktualisiert, versucht draw.dt aber ein neuer Fehler kam, in browers einen Fehler Konsole zeigt Uncaught TypeError: TransmittedDataTable.columns is not a function(…)

+0

Was versuchen Sie zu tun? Es klingt, als müssten Sie drawCallback verwenden. Ich merke, dass Sie etwas ausprobiert haben, aber es ist jetzt auskommentiert ... – markpsmith

Antwort

1

Sie sollten .dt hinzufügen Ereignisname, wenn Sie jQuery-Objekt verwendet oder Ihre Tabelle mit dataTable() initialisiert haben, siehe Beispiel unten.

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

}); 

Wenn Sie Ihre Tabelle initialisiert mit DataTable(), .dt Suffix ist nicht erforderlich.

Da Sie versuchen, Zugriff auf andere API-Methoden mit TransmittedDataTable Variable, initialisieren Sie Ihre Tabelle mit DataTable() und alles würde wie erwartet funktionieren.

Weitere Informationen finden Sie unter Events.

+0

Ich habe versucht, Ihren Code und es bereits auslösen das Ereignis, aber jetzt habe ich ein anderes Problem, 'Uncaught TypeError: TransmittedDataTable.columns ist keine Funktion (...)' – Angelo11292

+0

@ Angelo11292, initialisiere deine Tabelle mit 'DataTable()' anstelle von 'dataTable()' und alles funktioniert wie erwartet. –

+0

ja es funktioniert perfekt. Danke! – Angelo11292

Verwandte Themen