Подтвердить что ты не робот

Datatables: изменение цвета ячеек на основе значений

Я использую DataTable для создания интерактивной таблицы. У меня 9 столбцов, 5 из которых являются значениями. Я хочу изменить цвет фона каждой ячейки на основе их конкретных.

Я начал сначала пытаться изменить весь цвет строки, поскольку это казалось более простой задачей. Однако я не могу ничего изменить.

Мой код ниже:

    <head>  
    <link rel="stylesheet" type="text/css" href="//cdn.datatables.net/1.10.13/css/jquery.dataTables.css">
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.1.0/jquery.min.js"></script>
    <script type="text/javascript" charset="utf8" src="//cdn.datatables.net/1.10.13/js/jquery.dataTables.js"></script>      

    <script>
        $(document).ready(function(){
            $('#countryTable').DataTable();
        });
    </script>

    <script>
        $(document).ready( function () {
        $('#countryTable ').DataTable({
            "fnRowCallback": function( nRow, aData, iDisplayIndex, iDisplayIndexFull ) {
                if ( aData[3] > 11.7 )
                {
                    $(nRow).css('color', 'red')
                }
                else if ( aData[2] == "4" )
                {
                    $(nRow).css('color', 'green')
                }
            }
        });
    </script>

</head>

<body>      

    <table id ="countryTable" class="display" cellspacing="0" data-page-length='193'>
<thead>
    <tr>
        <th>Rank</th>
        <th>Country</th>
        <th>Code</th>
        <th>Total</th>
        <th>Beer</th>
        <th>Wine</th>
        <th>Spirits</th>
        <th>Other</th>
        <th>Score</th>
    </tr>
</thead>
<tbody>
    <tr>
        <td>1</td>
        <td>Estonia</td>
        <td>EE</td>
        <td>14.97</td>
        <td>5.87</td>
        <td>1.65</td>
        <td>5.64</td>
        <td>1.81</td>
        <td>3 - Medium Risky</td>
    </tr>
    <tr>
        <td>2</td>
        <td>Belarus</td>
        <td>BY</td>
        <td>14.44</td>
        <td>2.5</td>
        <td>0.75</td>
        <td>6.73</td>
        <td>4.46</td>
        <td>4 - Very Risky</td>
    </tr>

</tbody>

Я также попытался использовать следующую функцию, но не повезло. Если бы кто-нибудь мог помочь, это было бы очень appriciataed, поскольку я очень люблю java script.

$(document).ready( function () {
        $('#countryTable').DataTable({
            "fnRowCallback": function( nRow, aData, iDisplayIndex, iDisplayIndexFull ) {
                if ( aData[3] == "5" )
                {
                    $('td', nRow).css('background-color', 'Red');
                }
                else if ( aData[3] == "4" )
                {
                    $('td', nRow).css('background-color', 'Orange');
                }
            }
        });
4b9b3361

Ответ 1

Прежде всего, инициализируйте DataTable только один раз. Затем, согласно вашему вопросу, используйте rowCallback, а не fnRowCallBack, как показано ниже:

var oTable = $('#countryTable').DataTable({ 
    'rowCallback': function(row, data, index){
    if(data[3]> 11.7){
        $(row).find('td:eq(3)').css('color', 'red');
    }
    if(data[2].toUpperCase() == 'EE'){
        $(row).find('td:eq(2)').css('color', 'blue');
    }
  }
});

Здесь fiddle

Ответ 2

Я хотел бы добавить, если я объявлю столбец:

columns: [
                {data: 'id', name: 'riskdetails.id' },
                {data: 'name', name: 'riskdetails.name'}
]

поэтому вместо числа я должен написать имя в разделе if:


            'rowCallback': function (row, data, index) {

                if (data['name'] == 'Michael') {

                    $(row).find('td:eq(7)').css('background-color', 'red').css('color', 'white');

                } else {

                    $(row).find('td:eq(7)').css('background-color', 'blue').css('color', 'white');

                }

            }