如何删除dataTables按钮的默认按钮类?

我正在使用带有Button的数据表。 我想显示成功按钮而不是默认。 我试过这个代码

buttons: [ { extend: "excel", className: "btn-sm btn-success", titleAttr: 'Export in Excel', text: 'Excel' }] 

这段代码正在运行,但这是添加btn-success类,但是我想首先删除btn-default类,然后添加成功类。

当前类: "btn btn-default buttons-excel buttons-html5 btn-sm btn-success"

我想要的是: "btn buttons-excel buttons-html5 btn-sm btn-success"

是的,这真的很烦人。 不使用bootstrap是相同的,即使声明className也总是添加.dt-button 。 您可以使用init回调来修改示例类:

 $('#example').DataTable( { dom: 'Bfrtip', buttons: [{ extend: "excel", className: "btn-sm btn-success", titleAttr: 'Export in Excel', text: 'Excel', init: function(api, node, config) { $(node).removeClass('btn-default') } }] }); 

演示 – > https://jsfiddle.net/m6hysypd/


更新 :已收到很多关于此的赞成,但正确最佳答案实际上是“DavidDomains”的答案如下 。 使用

 buttons: { dom: { button: { className: '' } }, buttons: [{ //here comes your button definitions }] } 

你应该看一下buttons.dom.button选项。

buttons.dom.button

此选项控制用于创建每个按钮的HTML标记。 使用此选项,可以使用此对象的tag和className属性指定标记类型和类名。

这将使您完全控制按钮在DOM中的呈现方式。 之后无需删除任何课程。

这是一个例子。

 $('#example').DataTable( { dom: 'Bfrtip', buttons: { dom: { button: { tag: 'button', className: '' } }, buttons: [{ extend: 'excel', className: 'btn btn-sm btn-success', titleAttr: 'Excel export.', text: 'Excel', filename: 'excel-export', extension: '.xlsx' }, { extend: 'copy', className: 'btn btn-sm btn-primary', titleAttr: 'Copy table data.', text: 'Copy' }] } }); 
    
Name Position Office Age Start date Salary
Name Position Office Age Start date Salary
Tiger Nixon System Architect Edinburgh 61 2011/04/25 $320,800
Garrett Winters Accountant Tokyo 63 2011/07/25 $170,750
Ashton Cox Junior Technical Author San Francisco 66 2009/01/12 $86,000
Cedric Kelly Senior Javascript Developer Edinburgh 22 2012/03/29 $433,060
Airi Satou Accountant Tokyo 33 2008/11/28 $162,700

也许这可以帮助

 $('.dt-button').attr("class","btn-success"); 

加载Datatables后将其添加到jquery

或者您可以创建自己的css类并将require属性标记为!important以覆盖默认样式

使用此代码隐藏按钮上的Excel文本:

  extend: 'excel', text: '', className: "btn btn-info btn-sm glyphicon glyphicon-list-alt",