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

Posted

技术标签:

【中文标题】如何删除 dataTables 按钮的默认按钮类?【英文标题】:How can I remove default button class of a dataTables button? 【发布时间】:2017-12-31 03:17:47 【问题描述】:

我正在使用带有 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"

【问题讨论】:

我们需要知道您使用的是哪个库。 在 jquery $('#your_button_id').removeClass('btn-default'); 我正在使用 DataTables 1.10.11 库和 jquery-2.2.3 @DavidDomain 您想删除默认类...? @charley 就像我在上面的评论中所说的那样,我发布了一个答案。只需使用 buttons.dom.button 属性,它可以让您完全控制标签和类名的创建。无需做任何 JS hack。 【参考方案1】:

是的,这真的很烦人。不使用引导程序也是如此,即使您声明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”的答案below。使用

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

【讨论】:

是的,它对我有用...:) @ansh 我已经制定/找到了一个更好的解决方案现在演示 -> jsfiddle.net/aep2qfz5/22 来自:datatables.net/forums/discussion/51001【参考方案2】:

您应该看看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'
    ]
  
);
<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" >
  <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>

【讨论】:

【参考方案3】:

更改 Datatable 中所有按钮的默认类 (更新fiddle)

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

【讨论】:

【参考方案4】:

试试这个

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

【讨论】:

【参考方案5】:

也许这会有所帮助

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

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

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

【讨论】:

是你用的jquery,不要用attr修改类。【参考方案6】:

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

 extend: 'excel',

 text: '',

 className: "btn btn-info btn-sm  glyphicon glyphicon-list-alt",

【讨论】:

以上是关于如何删除 dataTables 按钮的默认按钮类?的主要内容,如果未能解决你的问题,请参考以下文章

如何在按钮单击时启用和禁用 jquery dataTables 的分页

数据表分页按钮 - 删除不需要的空间

如何更改 DataTables jQuery 插件的分页按钮数量

dataTables导出按钮显示在自定义位置?

dataTables导出按钮显示在自定义位置?

是否可以在 jQuery DataTables 中放置编辑和删除按钮?