How to get current table id to add to ajax data wh

2019-08-18 01:44发布

问题:

I have the following initialisation for multiple tables with the same class but different id attributes:

var $table = $('table.jobs');

$table.DataTable({

    ....
    ajax: {
        url: '/my-url',
        dataSrc: function (json) {

            return json.data
        },
        data: function(data) {

            data.table_id = $table.attr('id');
            // gives the same id for all tables

        }
    },
    ...
});

Is there a way I can identify which table is sending the ajax request? I'm trying to avoid duplicating the entire initialisation for every table.

回答1:

You can try something like this:

$('.table.jobs').each(function () {
    $('#'+$(this).attr('id')).dataTable({
         url: '/my-url',
    dataSrc: function (json) {

        return json.data
    },
    data: function(data) {

        data.table_id = $table.attr('id');
        // gives the same id for all tables

    }
});