I am using datatables and currently stuck in changing a row to another color if a STATEMENT meet the requirement, already tried many things but it has really weird error, my codes are :
"rowCallback": function( row, data, index ) {
        if ( data[2] < data[4] ) {
          $('td', row).css('background-color', 'pink');
        }
}
While in my response file, i wrote this query :
$sql = "SELECT itemid,itemname,stock,unit,minimum FROM item WHERE type LIKE 'homecare'";
I want to change the row color if the item's stock is LOWER than the minimum value set by the user.
My current datatable test results are :

Example test result i have run :
While the database settings for both row 'minimum' column are the same number (5)
Thanks for your help!
You seem to have 9 cc, 10 cc and so as values in the stock column? If you want numerical comparison you must extract the number for each column as number. I would also add a .pink class to the <tr>, instead of setting background-color on all <td>'s. 
"rowCallback": function( row, data, index ) {
  var stock = parseFloat(data[0]), //data[2]
      minimum = parseFloat(data[1]), //data[4]
      $node = this.api().row(row).nodes().to$();
  if (stock < minimum ) {
     $node.addClass('pink')
  } 
}      
demo -> http://jsfiddle.net/104o96cn/
New Datatable has the following feature for highlighting the row:
"rowCallback": function( row, data, index ) {
        if ( data[2] < data[4] ) {
          //Highlight the cell value
          $(row).find('td:eq(2)').css('color', 'red');
          //Highlight the row
          $(row).addClass("danger");
        }
}
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With