php - Codeigniter ajax 分页搜索结果不起作用

标签 php jquery ajax codeigniter pagination

我正在使用此站点的ajax分页方法并做了一些小的更改:https://www.codexworld.com/codeigniter-ajax-pagination-with-search-filter/ 这似乎工作正常,直到我在搜索后尝试使用分页。

例如。当我搜索某些内容时,分页链接会正确显示,但是当我单击下一页时,它会重置为默认分页。我错过了什么吗?我已经查找和比较了一整天,似乎找不到问题所在。我希望有人可以帮我看一下这个,看看我是否遗漏了一些东西。

这是ajax分页库

<?php  if (!defined('BASEPATH')) exit('No direct script access allowed');

class Ajax_pagination{

    var $base_url        = '';
    var $total_rows      = '';
    var $per_page        = 10;
    var $num_links       =  2;
    var $cur_page        =  0;
    var $first_link      = 'First';
    var $next_link       = '&#187;';
    var $prev_link       = '&#171;';
    var $last_link       = 'Last';
    var $uri_segment     = 3;
    var $full_tag_open   = '<ul class="pagination">';
    var $full_tag_close  = '</ul>';
    var $first_tag_open  = '<li>';
    var $first_tag_close = '</li>';
    var $last_tag_open   = '<li>';
    var $last_tag_close  = '<li>';
    var $cur_tag_open    = '<li class="active"><a href="#">';
    var $cur_tag_close   = '</a></li>';
    var $next_tag_open   = '<li>';
    var $next_tag_close  = '</li>';
    var $prev_tag_open   = '<li>';
    var $prev_tag_close  = '</li>';
    var $num_tag_open    = '<li>';
    var $num_tag_close   = '</li>';
    var $target          = '';
    var $anchor_class    = '';
    var $show_count      = false;
    var $link_func       = 'getData';
    var $loading         = '.loading';

    /**
     * Constructor
     * @access    public
     * @param    array    initialization parameters
     */
    function CI_Pagination($params = array()){
        if (count($params) > 0){
            $this->initialize($params);        
        }
        log_message('debug', "Pagination Class Initialized");
    }

    /**
     * Initialize Preferences
     * @access    public
     * @param    array    initialization parameters
     * @return    void
     */
    function initialize($params = array()){
        if (count($params) > 0){
            foreach ($params as $key => $val){
                if (isset($this->$key)){
                    $this->$key = $val;
                }
            }        
        }

        // Apply class tag using anchor_class variable, if set.
        if ($this->anchor_class != ''){
            $this->anchor_class = 'class="' . $this->anchor_class . '" ';
        }
    }

    function getCurrPage(){
        return $this->cur_page;
    }

    /**
     * Generate the pagination links
     * @access    public
     * @return    string
     */    
    function create_links(){
        // If our item count or per-page total is zero there is no need to continue.
        if ($this->total_rows == 0 OR $this->per_page == 0){
           return '';
        }

        // Calculate the total number of pages
        $num_pages = ceil($this->total_rows / $this->per_page);

        // Is there only one page? Hm... nothing more to do here then.
        if ($num_pages == 1){
//            $info = 'Showing : ' . $this->total_rows;
            $info = '';
            return $info;
        }

        // Determine the current page number.        
        $CI =& get_instance();    
        if ($CI->uri->segment($this->uri_segment) != 0){
            $this->cur_page = $CI->uri->segment($this->uri_segment);   
            // Prep the current page - no funny business!
            $this->cur_page = (int) $this->cur_page;
        }

        $this->num_links = (int)$this->num_links;
        if ($this->num_links < 1){
            show_error('Your number of links must be a positive number.');
        }

        if ( ! is_numeric($this->cur_page)){
            $this->cur_page = 0;
        }

        // Is the page number beyond the result range?
        // If so we show the last page
        if ($this->cur_page > $this->total_rows){
            $this->cur_page = ($num_pages - 1) * $this->per_page;
        }

        $uri_page_number = $this->cur_page;
        $this->cur_page = floor(($this->cur_page/$this->per_page) + 1);

        // Calculate the start and end numbers. These determine
        // which number to start and end the digit links with
        $start = (($this->cur_page - $this->num_links) > 0) ? $this->cur_page - ($this->num_links - 1) : 1;
        $end   = (($this->cur_page + $this->num_links) < $num_pages) ? $this->cur_page + $this->num_links : $num_pages;

        // Add a trailing slash to the base URL if needed
        $this->base_url = rtrim($this->base_url, '/') .'/';

        // And here we go...
        $output = '';

        // SHOWING LINKS
        if ($this->show_count){
            $curr_offset = $CI->uri->segment($this->uri_segment);
            $info = 'Showing ' . ( $curr_offset + 1 ) . ' to ' ;

            if( ( $curr_offset + $this->per_page ) < ( $this->total_rows -1 ) )
            $info .= $curr_offset + $this->per_page;
            else
            $info .= $this->total_rows;

            $info .= ' of ' . $this->total_rows . ' | ';
            $output .= $info;
        }

        // Render the "First" link
        if  ($this->cur_page > $this->num_links){
            $output .= $this->first_tag_open 
                    . $this->getAJAXlink( '' , $this->first_link)
                    . $this->first_tag_close;
        }

        // Render the "previous" link
        if  ($this->cur_page != 1){
            $i = $uri_page_number - $this->per_page;
            if ($i == 0) $i = '';
            $output .= $this->prev_tag_open 
                    . $this->getAJAXlink( $i, $this->prev_link )
                    . $this->prev_tag_close;
        }

        // Write the digit links
        for ($loop = $start -1; $loop <= $end; $loop++){
            $i = ($loop * $this->per_page) - $this->per_page;    
            if ($i >= 0){
                if ($this->cur_page == $loop){
                    $output .= $this->cur_tag_open.$loop.$this->cur_tag_close; // Current page
                }else{
                    $n = ($i == 0) ? '' : $i;
                    $output .= $this->num_tag_open
                        . $this->getAJAXlink( $n, $loop )
                        . $this->num_tag_close;
                }
            }
        }

        // Render the "next" link
        if ($this->cur_page < $num_pages){
            $output .= $this->next_tag_open 
                . $this->getAJAXlink( $this->cur_page * $this->per_page , $this->next_link )
                . $this->next_tag_close;
        }

        // Render the "Last" link
        if (($this->cur_page + $this->num_links) < $num_pages){
            $i = (($num_pages * $this->per_page) - $this->per_page);
            $output .= $this->last_tag_open . $this->getAJAXlink( $i, $this->last_link ) . $this->last_tag_close;
        }

        // Kill double slashes.  Note: Sometimes we can end up with a double slash
        // in the penultimate link so we'll kill all double slashes.
        $output = preg_replace("#([^:])//+#", "\\1/", $output);

        // Add the wrapper HTML if exists
        $output = $this->full_tag_open.$output.$this->full_tag_close;
        ?>
        <script>
        function getData(page){  
            $.ajax({
                method: "POST",
                url: "<?php echo site_url('/Common/Check'); ?>",
                success: function(data){
                    if(data==true){
                        console.log(page);
                        $.ajax({
                            method: "POST",
                            url: "<?php echo $this->base_url; ?>"+page,
                            data: { page: page },
                            beforeSend: function(){
                                $('<?php echo $this->loading; ?>').show();
                            },
                            success: function(data){
                                console.log("<?php echo $this->base_url; ?>"+page);
                                $('<?php echo $this->loading; ?>').hide();
                                $('<?php echo $this->target; ?>').html(data);
                            }
                        });
                    }else{
                        window.location.href="<?php echo site_url('/');?>";
                    }
                }
            });
        }
        </script>
        <?php
        return $output;
    }

        function getAJAXlink($count, $text) {
    $pageCount = $count?$count:0;
    return '<a href="javascript:void(0);"' . $this->anchor_class . ' data-per-
    page="'.$this->per_page.'" onclick="'.$this->link_func.'('.$pageCount.')">'. 
    $text .'</a>';
}
}

Controller

public function index()
    {
        $conditions = array();
        $data = array();
        $totalRec = count($this->ActivitiesModel->admin_get_and_search($conditions));
        $config['target']      = '#list';
        $config['base_url']    = site_url('/AdminActivities/Search');
        $config['total_rows']  = $totalRec;
        $config['per_page']    = $this->get_per_page();
        $this->ajax_pagination->initialize($config);
        $data['links'] = $this->ajax_pagination->create_links();
        $data['datatable'] = $this->ActivitiesModel->admin_get_and_search(array('limit'=>$this->get_per_page()));
        $data['user'] = $this->AccountModel->get_person($this->get_person_id());

        $this->load->view('layout/admins/common/header');
        $this->load->view('layout/admins/common/navigation');
        $this->load->view('layout/admins/common/title');
        $this->load->view('layout/admins/common/errors');
        $this->load->view('admins/activities/index',$data);
        $this->load->view('layout/admins/common/footer');
    }

    public function search(){
        $conditions = array();
        $page = $this->input->post('page');
        if(!$page){
            $offset = 0;
        }else{
            $offset = $page;
        }
        $keywords = $this->input->post('keywords');
        if(!empty($keywords)){
            $conditions['search']['keywords'] = $keywords;
        }
        $totalRec = count($this->ActivitiesModel->admin_get_and_search($conditions));
        $config['target']      = '#list';
        $config['base_url']    = site_url('/AdminActivities/Search');
        $config['total_rows']  = $totalRec;
        $config['per_page']    = $this->get_per_page();
        $this->ajax_pagination->initialize($config);
        $conditions['start'] = $offset;
        $conditions['limit'] = $this->get_per_page();
        $data['links'] = $this->ajax_pagination->create_links();
        $data['datatable'] = $this->ActivitiesModel->admin_get_and_search($conditions);
        $this->load->view('admins/activities/ajax_pagination', $data, false);
    }

查看

<script>

    function searchFilter() {
    // get current page number
    var page_num = parseInt($('li.active a').text()) - 1;
    // get active li parent element to get Data-Per-Page value
    var active_parent = $('li.active a').parent('li');
    console.log('page_num: ' + page_num);
    var item_per_page = parseInt(active_parent.prev('li').find('a').data('per-page'));
    // if NaN then use Next element
    if (isNaN(item_per_page)) {
        item_per_page = parseInt(active_parent.next('li').find('a').data('per-page'));
    }
    console.log('item_per_page: ' + item_per_page);
    // Query string Keyword
    var keywords = $('#search').val();
    console.log('keywords: ' + keywords);
    // Calculate the Offset
    var page = (page_num * item_per_page);
    console.log('page: ' + page);
    // attach custom payload to ajax post
    $.ajaxSetup({
        data: {
            'page': page_num,
            keywords: keywords
        },
    });
    $.ajax({
        method: "POST",
        url: "<?php echo site_url('/Common/Check'); ?>",
        success: function(data){
            if(data==true){
                $.ajax({
                    type: 'POST',
                    url: '<?php echo site_url('/AdminDocuments/Search/'); ?>'+page_num,
                    data:'page='+page_num+'&keywords='+keywords,
                    beforeSend: function () {
                        $('.loading').show();
                    },
                    success: function (html) {
                        $('#list').html(html);
                        $('.loading').fadeOut("slow");
                    }
                });
            }else{
                window.location.href="<?php echo site_url('AdminLogin');?>";
            }
        }
    });
    // Use same function to build filter output with pagination
    getData(page);
}        
</script>
<div id="maincontainer">
    <div class="row col-sm-8">
        <input type="text" name="search" id="search" class="form-control" placeholder="Search" onkeyup="searchFilter()"> 
    </div>
    <div id="list" class="row">
        <div class="col-sm-12 table-responsive">
            <table class="table">
                <tbody>
                    <?php 
                        if(!empty($datatable)){
                            foreach ($datatable as $data){
                    ?>
                        <tr class="text-left">
                            <td><?php echo $data['action']; ?> onto the <?php echo $data['page']; ?> Page on <?php echo $data['created_on']; ?></td>
                        </tr>
                    <?php 
                        }
                    }else{
                    ?>
                        <tr>
                            <td colspan="7">You do not have any items at the moment</td>
                        </tr>
                    <?php
                    }
                    ?>
                </tbody>
            </table>
        </div>
        <div class="pagination-links pull-right">
            <?php echo $links; ?>
        </div>
    </div>
    <div class="loading" style="display: none;">
        <div class="content">
            <img src="<?php echo base_url().'assets/images/loading/loading.gif'; ?>"/>
        </div>
    </div>
</div>

最佳答案

是的!,你失踪了...

You missing to pass 'page_num' in 'onkeyup="searchFilter()"'

您正在使用类似函数 searchFilter(page_num) { } 的函数,但没有发送“page_num”值(value)。因此,当您使用 AJAX 进行 POST 时,它将始终为“0”并且您的分页将会重置。

另一种方法是使用在 Ajax_pagination 库类中编写的相同 getData(page) 函数。在此之前,请在类中更改一点代码:

更新 Ajax_pagination > getAJAXlink 方法:

function getAJAXlink($count, $text) {
  $pageCount = $count?$count:0;
  return '<a href="javascript:void(0);"' . $this->anchor_class . ' data-per-
  page="'.$this->per_page.'" onclick="'.$this->link_func.'('.$pageCount.')">'. 
  $text .'</a>';
}

JavaScript:

<script type="text/javascript">
function searchFilter() {
    // get current page number
    var page_num = parseInt($('li.active a').text()) - 1;
    // get active li parent element to get Data-Per-Page value
    var active_parent = $('li.active a').parent('li');
    // get per page count
    var item_per_page = parseInt(active_parent.prev('li').find('a').data('per-page'));
    // if NaN then use Next element
    if (isNaN(item_per_page)) {
        item_per_page = parseInt(active_parent.next('li').find('a').data('per-page'));
    }
    // Query string Keyword
    var keywords = $('#search').val();
    // Calculate the Offset
    var page = (page_num * item_per_page);
    // attach custom payload to ajax post
    $.ajaxSetup({
        data: {
            'page': page_num,
            keywords: keywords
        },
    });
    // No Need to your Ajax Code Here, The getData already gives you filtered data
    // and will set in #list, basically getData posting Common/Check url and getting data
    // Here is getData post request analysis report.... :)    
    // Use same function to build filter output with pagination
    getData(page);
}
</script>

了解 Ajax_pagination 类中 getData Ajax 请求的流程

<script type="text/javascript">
function getData(page) {
    // ajax start
    $.ajax({
        method: "POST",
        // sending request to Common/Check Controller/method
        url: "<?php echo site_url('/Common/Check'); ?>",
        success: function(data) {
            // if response returns
            if (data) {
                console.log(page);
                // call another ajax request
                $.ajax({
                    method: "POST",
                    // sending request to Class Ajax_pagination Config base_url link
                    url: "<?php echo $this->base_url; ?>" + page,
                    // sending payloads page e.g. 10, 20, 30...
                    data: {
                        page: page
                    },
                    beforeSend: function() {
                        $('<?php echo $this->loading; ?>').show();
                    },
                    success: function(data) {
                        // if response returns
                        console.log("<?php echo $this->base_url; ?>" + page);
                        $('<?php echo $this->loading; ?>').hide();
                        // set response inside Ajax_pagination Config target element e.g #list
                        $('<?php echo $this->target; ?>').html(data);
                    }
                });
            } else {
                window.location.href = "<?php echo site_url('/');?>";
            }
        }
    });
}            
</script>

一个好方法是使用 CodeIgniter 内置分页类。这非常简单,您只需通过 Google 搜索即可找到大量示例代码。

然后您可以组合您的 Controller 、模型和 View 来创建 Ajax 响应,毕竟返回一个包含数据的表格 html 行就可以了 或 返回一些 div 奇特的内容。背后的逻辑是,您可以通过在 Controller 内使用CodeIgniter Pagination Class来调用简单的ajax来构建您的内容,并且可以通过传递限制和偏移量来通过模型获取数据,就是这样!

来源和文档:CodeIgniter Pagination Class

@JianYA,请经常检查浏览器网络面板,看看我们在使用 Ajax 时得到了什么响应。它可能会消除更多疑问,而不是假设。您正在 getData 函数 中使用“Common/Check”,所以这里有一些问题要问您:

  1. 你们有通用的 Controller 和检查方法吗?
  2. 您是否设置了 $route['Common/Check'] = 'YourController/YourMethod'; 如果您没有此 Controller ,则在 config 文件夹 内的 routes.php

关于php - Codeigniter ajax 分页搜索结果不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44734796/

相关文章:

php - 使用 php 将数据插入 MySql 后使用 SweetAlert 显示消息

php - 仅获取登录用户帖子

javascript - 在 jQuery 中创建元素;创建、包装、追加

php - 如何在 Laravel 5.5 中正确编写 Controller 方法的单元测试?

jquery - Razor bool html5 属性被大写阻止了 jquery 中的条件语句

javascript - 这是使用 jQuery 将 HTML 转换为文本的有效方法吗?

javascript - 将 javascript 变量传递给 AJAX 成功函数

jquery - IE SCRIPT5 : Access is denied. 被 jQuery 的同域 ajax 请求抛出

php - PHP 中两个时间戳之间的差异

php - 仅显示目录名称