Если у вас есть <table>
с идентификатором myTable
и именем Your Name Here
(просто в качестве заполнителя), вы можете использовать следующее:
$(document).ready(function() {
$('#myTable').DataTable( {
dom: 'Bfrtip',
buttons: [
{ extend : 'collection',
text : '<i class="fa fa-bars">buttons</i>',
buttons: [
'copy', 'csv', 'excel', 'pdf', 'print',
{
text: 'Report Issue',
action: function ( e, dt, node, config ) {
reportIssue(e, dt, node, config);
}
}
]
}]
} );
// e - the button click event
// dt - the datatable object
// node - button node
// config - the button's config (e.g. 'text')
function reportIssue(e, dt, node, config) {
var tableName = $('#myTable').attr('name');
alert( 'The "' + config.text + '" button was clicked\n'
+ 'for the "' + tableName + '" table.' );
}
});
Сердце Решением является эта часть, где пользовательская кнопка объявляется:
{
text: 'Report Issue',
action: function ( e, dt, node, config ) {
reportIssue(e, dt, node, config);
}
}
Примечания:
Я добавил слово «кнопки» к главной кнопке, просто чтобы она не была пустой:
data:image/s3,"s3://crabby-images/b484f/b484fb050e83d63162cc9da3b81ce753921a57b7" alt="enter image description here"
Когда вы нажимаете на это, вы видите следующий набор кнопок:
data:image/s3,"s3://crabby-images/2e3a9/2e3a991285a4144f26648c0011063f43a7e4ba38" alt="enter image description here"
После этого вам решать, что вы добавите в функцию reportIssue()
. Вам может не понадобиться ни одна из переменных, переданных ему. Вероятно, нет, основываясь на примере JS в вопросе (я использовал предупреждение, только для тестирования).