2017-10-09 95 views
1

我在Codeigniter和分頁時遇到了一些問題。問題是我得到所有頁面上的所有結果/帖子。Codeigniter - 分頁不起作用

我在使用Codeigniter和分頁時遇到了一些問題。問題是我得到所有頁面上的所有結果/帖子。

這是我的控制器代碼:

public function __construct() 
{ 
    parent::__construct(); 

    $this->load->model('SS_shilpi_model'); 
    $this->load->library('form_validation'); 
    $this->load->library('pagination'); 
} 

public function category(){ 
    $cid = $this->input->post('cid'); 
    if(isset($_GET['cid'])) 
    { 
     $cid = $_GET['cid']; 
     $this->SS_shilpi_model->catr3($cid); 
     $this->SS_shilpi_model->catr3_nr($cid); 
    } 

    $config = [ 
     'base_url' => base_url('category/?cid='. $cid .' '), 
     'per_page' => 12, 
     'total_rows' => $this->SS_shilpi_model->catr3_nr($cid), 
    ]; 

    $config['full_tag_open'] = '<ul style="overflow: hidden;" class="pagination">'; 
    $config['full_tag_close'] = '</ul>'; 
    $config['num_tag_open'] = '<li class="page-item">'; 
    $config['num_tag_close'] = '</li>'; 
    $config['cur_tag_open'] = '<li class="page-item active"><a class="page-link" href="#">'; 
    $config['cur_tag_close'] = '</a></li>'; 
    $config['next_tag_open'] = '<li class="page-item">'; 
    $config['next_tagl_close'] = '</a></li>'; 
    $config['prev_tag_open'] = '<li class="page-item">'; 
    $config['prev_tagl_close'] = '</li>'; 
    $config['first_link'] = 'First <i class="fa fa-caret-left fa-2x push-left-5 pull-right green-text"></i>'; 
    $config['first_tag_open'] = '<li class="page-item disabled">'; 
    $config['first_tagl_close'] = '</li>'; 
    $config['last_link'] = '<i class="fa fa-caret-right fa-2x push-left-5 pull-right green-text"></i> Last'; 
    $config['last_tag_open'] = '<li class="page-item">'; 
    $config['last_tagl_close'] = '</a></li>'; 
    $config['attributes'] = array('class' => 'page-link'); 
    $this->pagination->initialize($config); // model function 

    $data['catr3d'] = $this->SS_shilpi_model->catr3($cid, $config['per_page'], $this->uri->segment(3)); // list of Category Details 
    // end pagination 

    $this->load->view('shilpi/category',$data); 
} 

我的標準守則:

public function catr3($cid){ 
    $this->db->select(''); 
    $this->db->order_by('id', 'DESC'); 
    $this->db->where('category_id',$cid); 
    $query = $this->db->get('all_posts'); 
    return $query->result(); 
} 

public function catr3_nr($cid){ 
    $this->db->select(''); 
    $this->db->order_by('id', 'DESC'); 
    $this->db->where('category_id',$cid); 
    $query = $this->db->get('all_posts'); 
    return $query->num_rows(); 

} 

我的視圖代碼:

<div id="catdata" class="col-xs-12 no-pull push-up-5 push-down-5 briefs"> 

       <?php 
        $count =1; 
        foreach($catr3d as $r) 
        { 

        if($count%4 == 1) 
        { 
          echo '<div class="col-xs-12 no-pull push-down-5">'; 

        } 

        ?> 

       <div class="col-sm-3 col-xs-12 no-pull-left pull-right-5"> 
        <div class="brief whitish-bg pull-5"> 
         <p class="red-text no-push"> 
          <?php echo $r->short_title; ?> 
         </p> 
         <a href="<?php echo base_url(); ?>details/?pid=<?php echo $r->id; ?>"> 
          <h5 class="blue-text font17 push-up-5"> 
           <?php echo $r->title; ?> 
          </h5> 
         </a> 
         <p> 
          <a href="<?php echo base_url(); ?>details/?pid=<?php echo $r->id; ?>"> 
           <img src="<?php echo base_url(); ?>upload/images/<?php echo $r->photo;?>" height="75" width="100" class="pull-left push-right-5 push-up-5"></img> 
          </a> 
          <?php 
         $string = $r->news; 
         $string = strip_tags($string); 

         if (strlen($string) > 500) { 


          $pos=strpos($string, ' ', 900); 
          $stringCut=substr($string,0,$pos); 
          echo $stringCut; 
         } 
          else { 
          echo $string; 
          } 

         ?> 
          <a href="<?php echo base_url(); ?>details/?pid=<?php echo $r->id; ?>"><i class="fa fa-caret-right fa-2x push-left-5 pull-right green-text"></i></a> 
         </p> 
        </div> 
       </div> 
       <?php 
       if ($count%4 == 0) 
        { 
         echo "</div>"; 
        } 
        $count++; 
       ?> 
       <div class="clear: both"></div> 
       <?php 
       } 
       if ($count%4 != 1) echo "</div>"; 
       ?> 

       <?= $this->pagination->create_links() ?> 

     </div> 
+0

試試這個https://www.sitepoint.com/pagination-with-codeigniter/注意,您可能需要設置在配置部分航線/ route.php HTTP: //www.codeigniter.com/user_guide/general/routing.html#examples – user4419336

回答

0

這添加到控制器開始,限制你的模型函數論點

$page = ($this->uri->segment(3)) ? $this->uri->segment(3) : 0; 
    $data['posts'] = $this->post->get_posts($config["per_page"], $page); 

而繼以功能get_posts模型

$this->db->limit($limit, $start);