一般在數據分頁的時候需要獲取當前頁的數據和總條數,一般人是在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;
}
才對吧,經過修改後,這個問題沒有了。