Ошибка добавления html из ajax ответа на DataTable - PullRequest
0 голосов
/ 16 апреля 2020

Моя таблица показывает, что она не нашла никаких результатов в первой строке, а в следующих строках показывает результаты ... еще раз, если я пытаюсь отфильтровать свои данные по идентификатору или другому столбцу или даже искать что-то все мои данные исчезают и появляются только после перезагрузки страницы. Также показано, что показывается 0 записей, но отображаются некоторые записи. В чем здесь может быть проблема?

Пример:

при загрузке страницы

после фильтрации по некоторому столбцу

Ajax код при загрузке страницы:

$( document ).ready(function() {
        $.ajax({
            type : "POST",
            url  : "<?php echo base_url(); ?>CRUD_Controller/crud_getDataAll/nivel/niveis",
            cache: false,
            contentType: false, 
            processData: false,
            dataType: 'html',
            success: function(data){

                //alert("sucesso - " + data);
                $('#example1 tbody').append(data);

            },
            error:function(xhr)
            {
                alert('Algo falhou, nao caregou a tabela. - ' + xhr.statusText);
            }
        });
    });

Моя таблица данных Инициализация:

$(function () {
    $("#example1").DataTable();
});

//Portugues
$('#example1').DataTable({
    "language": {
        "sProcessing":    "Procesando...",
        "sLengthMenu":    "Mostrar _MENU_ registos",
        "sZeroRecords":   "Não foram encontrados resultados",
        "sEmptyTable":    "Nenhum dado dísponivel nesta tabela",
        "sInfo":          "A mostrar registos de _START_ a _END_ de um total de _TOTAL_ registos",
        "sInfoEmpty":     "Mostrando registos de 0 a 0 de um total de 0 registos",
        "sInfoFiltered":  "(filtrado de um total de registos _MAX_)",
        "sInfoPostFix":   "",
        "sSearch":        "Pesquisar:",
        "sUrl":           "",
        "sInfoThousands":  ",",
        "sLoadingRecords": "A carregar...",
        "oPaginate": {
            "sFirst":    "Primeiro",
            "sLast":    "Último",
            "sNext":    "Seguinte",
            "sPrevious": "Anterior"
        },
        "oAria": {
            "sSortAscending":  ": Ative para ordenar a coluna em ordem ascendente",
            "sSortDescending": ": Ative para ordenar a coluna em ordem decrescente"
        }
    }
});

Мой случай контроллера:

case 'niveis':
            $rows = $this->Administracao_model->getAllData($table_name);
            foreach($rows as $row) {
                echo '<tr>';
                echo '<td class="align-middle text-center"><a href="#">#NIV' . $row->id . '</a></td>';
                echo '<td class="align-middle text-center"><span class="badge ' . $row->classe . '">' . $row->nome . '</span></td>';

                ($row->adicionar == 1) ? $adicionar = "Adicionar" : $adicionar = "";
                ($row->remover == 1) ? $remover = ", Remover" : $remover = "";
                ($row->alterar == 1) ? $alterar = ", Alterar" : $alterar = "";
                ($row->pesquisar == 1) ? $pesquisar = ", Pesquisar" : $pesquisar = "";

                echo '<td class="align-middle text-center">' . $adicionar, $remover, $alterar, $pesquisar . '</td>';

                if($row->id == 1){
                    echo '<td class="align-middle text-center" data-toggle="tooltip" data-placement="top" title="Não é possível remover o nível 0 do sístema."><a href="#" class="btn btn-danger text-white btn-sm disabled" disabled="disabled"><i class="fas fa-trash"></i></a></td>';
                }else{
                    echo '<td class="align-middle text-center"><a href="#" class="btn btn-danger text-white btn-sm" onclick="showModalCerteza(' . $row->id . ')"><i class="fas fa-trash"></i></a></td>';
                }
                echo '</tr>';
            }
            break;

Пожалуйста, помогите, я попытался переключить append () на HTML (), но все равно таблица теряет свои данные при поиске или фильтрации.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...