如何删除数据表按钮的默认按钮类?



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

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

这段代码可以工作,但这是添加 btn 成功类,但我想先删除 btn 默认类,然后再添加成功类。

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

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

是的,这可能真的很烦人。不使用引导程序也是如此,即使您声明.dt-buttonclassName也始终添加。有一个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 标记。使用此选项,可以使用此对象的标记和类名属性指定标记类型和类名。

这将使您能够完全控制按钮在 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'
}]
}
});
<link href="https://cdn.datatables.net/v/bs-3.3.7/jszip-3.1.3/pdfmake-0.1.27/dt-1.10.15/b-1.3.1/b-html5-1.3.1/b-print-1.3.1/datatables.min.css" rel="stylesheet"/>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://cdn.datatables.net/v/bs-3.3.7/jszip-3.1.3/pdfmake-0.1.27/dt-1.10.15/b-1.3.1/b-html5-1.3.1/b-print-1.3.1/datatables.min.js"></script>
<table id="example" class="display" cellspacing="0" width="100%">
<thead>
<tr>
<th>Name</th>
<th>Position</th>
<th>Office</th>
<th>Age</th>
<th>Start date</th>
<th>Salary</th>
</tr>
</thead>
<tfoot>
<tr>
<th>Name</th>
<th>Position</th>
<th>Office</th>
<th>Age</th>
<th>Start date</th>
<th>Salary</th>
</tr>
</tfoot>
<tbody>
<tr>
<td>Tiger Nixon</td>
<td>System Architect</td>
<td>Edinburgh</td>
<td>61</td>
<td>2011/04/25</td>
<td>$320,800</td>
</tr>
<tr>
<td>Garrett Winters</td>
<td>Accountant</td>
<td>Tokyo</td>
<td>63</td>
<td>2011/07/25</td>
<td>$170,750</td>
</tr>
<tr>
<td>Ashton Cox</td>
<td>Junior Technical Author</td>
<td>San Francisco</td>
<td>66</td>
<td>2009/01/12</td>
<td>$86,000</td>
</tr>
<tr>
<td>Cedric Kelly</td>
<td>Senior Javascript Developer</td>
<td>Edinburgh</td>
<td>22</td>
<td>2012/03/29</td>
<td>$433,060</td>
</tr>
<tr>
<td>Airi Satou</td>
<td>Accountant</td>
<td>Tokyo</td>
<td>33</td>
<td>2008/11/28</td>
<td>$162,700</td>
</tr>
</tbody>
</table>

更改数据表中所有按钮的默认类 (更新的小提琴(

$.fn.dataTable.Buttons.defaults.dom.button.className = 'btn'; //'btn btn-primary'

试试这个

$('.dt-button').removeClass("dt-button");  

也许这会有所帮助

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

加载数据表后将其添加到 jquery

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

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

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

最新更新