Ajax List is error, просто показывает 5 данных из всех данных в базах данных? - PullRequest
0 голосов
/ 11 июля 2020

У меня 10 строк в моей таблице, но когда я хочу показать все строки в таблице данных (ajax), она не отображается, таблица данных просто показывает 5 строк из 10 в целом.

В этом случае я использую Codeigniter 3 & MySQL,

Это скриншот таблицы данных в моих приложениях:

это изображение или изображение моих приложений

это модель> M_Kelas:

<?php
class M_Kelas extends CI_Model{ 
    
    public function cek_kelas(){
        $nama = $this->input->post('nama');
        
        $query = $this->db->query("SELECT nama_kelas FROM kelas WHERE nama_kelas='$nama'" );
        if($query->num_rows() > 0){
            return $query->result();
        }else{
            return false;
        }

    }
    
    public function detail_kelas(){
        $id = $this->input->get('id');
        $query = $this->db->query("SELECT * FROM kelas WHERE kode='$id'" );
        return $query->result();

    }
    
    public function edit_kelas($id){
        $nama= $this->input->post('nama');
            
        $data = array(
                        'nama_kelas' => $nama
                    );
        $this->db->where('kode', $id);
        $result = $this->db->update('kelas', $data);
        return $result;
    }
    
    public function hapus_kelas($id){
        $this->db->where('kode', $id);
        $result = $this->db->delete('kelas');
        return $result;
    }
    
    public function semua_kelas(){
        $query = $this->db->query("SELECT * FROM kelas order by kode asc");
        return $query->result();
    
    }
    
    
    public function simpan_kelas($nama){
        
        $data = array(
                        'nama_kelas' => $nama
                    );
        $result=$this->db->insert('kelas',$data);
        
        return $result;
    }
    
    
}
?>

это контроллер> kelas / ajax_list:

public function ajax_list()
    {
        $list = $this->kelas->get_datatables();
        $data = array();
        $no = $_POST['start'];
        foreach ($list as $kelas) {
            $no++;
            $row = array(
                "id_kelas" => $kelas['id_kelas'],
                "kd_pelajaran" => $kelas['kd_pelajaran'],
                "nama_pelajaran" => $kelas['nama_pelajaran'],
                "nama_guru" => $kelas['nama_guru'],
                "nama_prodi" => $kelas['nama_prodi'],
                "kelas" => $kelas['kelas'],
                "kapasitas" => $kelas['kapasitas']
            );


            $data[] = $row;
        }

        $output = array(
            "draw" => $_POST['draw'],
            "recordsTotal" => $this->kelas->count_all(),
            "recordsFiltered" => $this->kelas->count_filtered(),
            "data" => $data,
        );
        //output to json format
        echo json_encode($output);
    }

А это мой взгляд> viewKelas:

table = $('#example-table').DataTable({

            "processing": true, //Feature control the processing indicator.
            "serverSide": true, //Feature control DataTables' server-side processing mode.
            "order": [], //Initial no order.

            // Load data for the table's content from an Ajax source
            "ajax": {
                "url": "<?php echo base_url('kelas/ajax_list') ?>",
                "type": "POST"
            },
            "columns": [{
                    "data": "kd_pelajaran"
                },
                {
                    "data": "nama_pelajaran"
                },
                {
                    "data": "nama_guru"
                },
                {
                    "data": "kelas"
                },
                {
                    "data": "nama_prodi"
                },
                {
                    "data": "kapasitas"
                },
                {
                    "data": "id_kelas",
                    render: function(data) {
                        var btn = "<a class='btn btn-sm btn-primary' href='javascript:void()' title='Edit' onclick='edit_data(" + data + ")'><i class='fa fa-edit'></i></a>&nbsp&nbsp<a class='btn btn-sm btn-danger' href='javascript:void()' title='Hapus' onclick='delete_this(" + data + ")'><i class='fa fa-trash-o'></i></a>";
                        return btn;
                    }
                }
            ],
            //Set column definition initialisation properties.
            "columnDefs": [{
                "targets": [-1], //last column
                "orderable": false, //set not orderable
            }, ],

        });

1 Ответ

0 голосов
/ 23 июля 2020

Значение «recordsFiltered» отличается от «recordsTotal». «RecordsFiltred» - это количество элементов после globalSearch или columnSearch.

Если поиск отсутствует (globalSearch или columnSearch), тогда значение «recordsFiltered» равно «recordsTotal».

прочтите это: https://datatables.net/forums/discussion/25985/resolved-datatables-server-side-problem-to-pagination-number-of-page-not-correct

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