最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - How to change DataTables row color - Stack Overflow

programmeradmin9浏览0评论

I have a table draw by DataTables. For every rows, last column of the table is a buttom which shows other jquery element (bxslider in my case, but it does not matter here). I want to be able to change the color of a row when I click on it buttom. I found some solutions but these only change the color before draw a DataTable, not running when a DataTables is draw already.

The buttoms have the html class "onclick".

I draw a datatable as follows:

$(div).DataTable({"data" : dataSet, "columns": columns})

Haw can I do that?

Thank you, regards. Mike

I have a table draw by DataTables. For every rows, last column of the table is a buttom which shows other jquery element (bxslider in my case, but it does not matter here). I want to be able to change the color of a row when I click on it buttom. I found some solutions but these only change the color before draw a DataTable, not running when a DataTables is draw already.

The buttoms have the html class "onclick".

I draw a datatable as follows:

$(div).DataTable({"data" : dataSet, "columns": columns})

Haw can I do that?

Thank you, regards. Mike

Share Improve this question edited Oct 25, 2017 at 9:33 Miguel.G asked Oct 25, 2017 at 9:18 Miguel.GMiguel.G 3871 gold badge7 silver badges22 bronze badges 2
  • Show some CODE also. So, we can help you further. – Harsh Patel Commented Oct 25, 2017 at 9:18
  • I write something else but I don't know what code do you need. My JS code run against the webpage, there is not more code which envolves the DataTables I'm talking about. – Miguel.G Commented Oct 25, 2017 at 9:35
Add a ment  | 

2 Answers 2

Reset to default 4

Will something like this work?

//initialise datatables on DOM load
$(document).ready(function() {
  $('#example').DataTable();
});

//on clicking the row
$("tbody tr").on("click", function() {
  //loop through all td elements in the row
  $(this).find("td").each(function(i) {
    //toggle between adding/removing the 'active' class
    $(this).toggleClass('active');
  });
});
/* Set !important rule to override default colors */
.active {
  background: gold !important;
}
<script src="https://ajax.googleapis./ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://cdn.datatables/1.10.16/js/jquery.dataTables.min.js"></script>
<link href="https://cdn.datatables/1.10.16/css/jquery.dataTables.min.css" rel="stylesheet" />

<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>
  </tbody>
</table>

    $('#dataTable').on('click', 'tr', function () {
        $(this).css("background-color", "#eeeeee");
    });
发布评论

评论列表(0)

  1. 暂无评论