we have a table in our page, with a few rows and a custom toggle button at the end. the table is loaded via html in the page, not via json.
now, the togglebutton at the end posts to a service and sets the follow state of that record in the database.
however, it should also make an update to another cell in that row. however i'm sure i should not do this via jquery manually but via datatables?
$('#tblFollow').dataTable({
    sDom: "t",
    aoColumns: [
      null,
      null,
      null,
      { bSortable: false }
    ]
});
$('#tblFollow').on('click', 'a.follow', function(e){
    $(this).toggleClass('active');
    // updating column 'following' here... 
    // but this only changes visually, and not the inner datatables data used for sorting
    var followingCell = $(this).parents('td').prev();
    var txt = followingCell.text() == "1" ? "0" : "1";
    followingCell.text(txt);
    return false;
});
manual example: now i have an example, where i change the fields manually, but that's only visual, the datatable still uses its inner data for sorting. So i'm looking for a way to do it better
Here is a possible solution:
In addition to your code you should update the datatables data as following
var rowIndex = table.fnGetPosition( $(this).closest('tr')[0] );
var aData = table.fnGetData( rowIndex  );
aData[2] = txt; //third column
Here the jsfiddle
And even better solution would be to use fnUpdate to update the data and display in the same time
Here the jsfiddle
// update column following here... 
var followingCell = $(this).parents('td').prev();
var txt = followingCell.text() == "1" ? "0" : "1";
var rowIndex = table.fnGetPosition( $(this).closest('tr')[0] );
table.fnUpdate( txt, rowIndex , 2);
Also instead of us
var followingCell = $(this).parents('td').prev();
var txt = followingCell.text() == "1" ? "0" : "1";
use
var aData = table.fnGetData( rowIndex  );
aData[2] //use it to check if the value is 0 or 1
                        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