程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> PHP綜合 >> Codeigniter(CI)框架分頁函數及相關知識

Codeigniter(CI)框架分頁函數及相關知識

編輯:PHP綜合

一般在數據分頁的時候需要獲取當前頁的數據和總條數,一般人是在model中封裝兩個函數分別獲取當前頁的數據和數據總條數,業務邏輯類似,感覺有點冗余,可以封裝在一起:

復制代碼 代碼如下:
/**
     * 獲取分頁數據及總條數
     * @param string @tablename 表名
     * @param mixed $where 條件
     * @param int $limit 每頁條數
     * @param int $offset 當前頁
     */
    public function get_page_data($tablename, $where, $limit, $offset, $order_by, $db)
    {
        if(empty($tablename))
        {
            return FALSE;
        }
       
        $dbhandle = empty($db) ? $this->db : $db;
       
        if($where)
        {
            if(is_array($where))
            {
                $dbhandle->where($where);
            }
            else
            {
                $dbhandle->where($where, NULL, false);
            }
        }
       
        $db = clone($dbhandle);
        $total = $dbhandle->count_all_results($tablename);
       
        if($limit)
        {
            $db->limit($limit);
        }
       
        if($offset)
        {
            $db->offset($offset);
        }
       
        if($order_by)
        {
            $db->order_by($order_by);
        }
       
        $data = $db->get($tablename)->result_array();
       
        return array('total' => $total, 'data' => $data);
    }

CI框架分頁類使用心得

CI分頁的url地址有四種方式
a) locahost/news/page/2 這個2表示第二頁
b) localhost/news/page/20 這個20表示從第20條記錄開始分頁,即頁面的第一條記錄,是數據庫中的第20條記錄。
c) localhost/news?per_page=2 第二頁
d) localhost/news?per_page=20 同b)

首先我們先看一下CI分頁的參數:

復制代碼 代碼如下:
$config['base_url'] = $url;  
/* 分頁的基礎 URL
如果你想用a、b的鏈接形式,則該url應該形式如/news/page/ 
如果鏈接是c、d的形式,則url應該如/news? 
*/ 
$config['total_rows'] = $total;//記錄總數,這個沒什麼好說的了,就是你從數據庫取得記錄總數  
$config['per_page'] = $pagesize; //每頁條數。額,這個也沒什麼好說的。。自己設定。默認為10好像。  
$config['page_query_string'] = TRUE;  
/*傳參形式。開啟true則會自動在你的url後面加上&per_page=3。(這個per_page是默認的查詢字符,當然你也可以用$config['query_string_segment']來自己設定)
因此c、d中的形式一般是為localhost/news?&per_page=2不過都一樣,沒什麼影響。get的per_page還是3 
*/ 
$config['first_link'] = '首頁'; // 第一頁顯示  
$config['last_link'] = '末頁'; // 最後一頁顯示  
$config['next_link'] = '下一頁 >'; // 下一頁顯示  
$config['prev_link'] = '< 上一頁'; // 上一頁顯示  
$config['cur_tag_open'] = ' <a class="current">'; // 當前頁開始樣式  
$config['cur_tag_close'] = '</a>';  
/*當前頁結束樣式。這些你可以自己嘗試一下。
比如說我想讓當前頁的分頁數字樣式好看一點,紅色字體等。你就可以在current上加上css代碼 
*/ 
$config['num_links'] = 2;// 當前連接前後顯示頁碼個數。意思就是說你當前頁是第5頁,那麼你可以看到3、4、5、6、7頁。  
$config['uri_segment'] = 4;  
/*這個是你在用a)、b)鏈接樣式的時候,用來判斷頁頁數。
比如localhost/news/page/3  這個uri_segment就要設定為3。localhost/news/title/page/3這個就要設定為4 
*/ 
$config['use_page_numbers'] = TRUE;  
/*這個就是a)、b)的差別了。開啟了,page就會表示頁數。false就會表示記錄數
*/ 

剛開始在網上查資料的時候,有很多這種寫法。

復制代碼 代碼如下:
$this->model->get_news($config['per_page'],$this->uri->segment(3)); 

其實這種寫法就是針對b)這種連接形式的。這裡的$this->uri->segment(3)就是取到page/20中的記錄數20。$config['per_page']就是限制輸出多少條。
有很大的局限性和誤導性。我開始就是死都不知道為什麼這麼寫。。後來才發現,手冊才是最好的老師。

當我們把CI分頁類的一些參數都配置好了之後,$this->pagination->initialize($config);//配置分頁

復制代碼 代碼如下:
$page = $this->pagination->create_links();  //我們就得到了分頁了 

直接傳遞到視圖頁,即可。

至於怎麼加載模型,怎麼存取數據記錄,怎麼傳遞變量到視圖,這裡就不說了,看手冊好了。

忘記說了,帶查詢參數的分頁,我是這麼做的。視圖中將查詢參數get提交到控制器的search方法。在search中,用$get = $this->input->get();去獲取到查詢參數。
然後加載model,用帶查詢參數和分頁參數去讀取記錄,將結果顯示到視圖。。

另外還發現個小bug,比如/news/page/-1000這樣的時候,下面的分頁鏈接將會出現負值
發現system/libraries/Pagination.php代碼如下

復制代碼 代碼如下:
if ($this->use_page_numbers AND $this->cur_page == 0)  
{  
    $this->cur_page = $base_page;  
}  
//應為  
if ($this->use_page_numbers AND $this->cur_page <= 0)  
{  
    $this->cur_page = $base_page;  


才對吧,經過修改後,這個問題沒有了。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved