Codeigniter(CI)框架分頁(yè)函數(shù)及相關(guān)知識(shí)
一般在數(shù)據(jù)分頁(yè)的時(shí)候需要獲取當(dāng)前頁(yè)的數(shù)據(jù)和總條數(shù),一般人是在model中封裝兩個(gè)函數(shù)分別獲取當(dāng)前頁(yè)的數(shù)據(jù)和數(shù)據(jù)總條數(shù),業(yè)務(wù)邏輯類似,感覺有點(diǎn)冗余,可以封裝在一起:
/**
* 獲取分頁(yè)數(shù)據(jù)及總條數(shù)
* @param string @tablename 表名
* @param mixed $where 條件
* @param int $limit 每頁(yè)條數(shù)
* @param int $offset 當(dāng)前頁(yè)
*/
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框架分頁(yè)類使用心得
CI分頁(yè)的url地址有四種方式
a) locahost/news/page/2 這個(gè)2表示第二頁(yè)
b) localhost/news/page/20 這個(gè)20表示從第20條記錄開始分頁(yè),即頁(yè)面的第一條記錄,是數(shù)據(jù)庫(kù)中的第20條記錄。
c) localhost/news?per_page=2 第二頁(yè)
d) localhost/news?per_page=20 同b)
首先我們先看一下CI分頁(yè)的參數(shù):
$config['base_url'] = $url;
/* 分頁(yè)的基礎(chǔ) URL
如果你想用a、b的鏈接形式,則該url應(yīng)該形式如/news/page/
如果鏈接是c、d的形式,則url應(yīng)該如/news?
*/
$config['total_rows'] = $total;//記錄總數(shù),這個(gè)沒什么好說的了,就是你從數(shù)據(jù)庫(kù)取得記錄總數(shù)
$config['per_page'] = $pagesize; //每頁(yè)條數(shù)。額,這個(gè)也沒什么好說的。。自己設(shè)定。默認(rèn)為10好像。
$config['page_query_string'] = TRUE;
/*傳參形式。開啟true則會(huì)自動(dòng)在你的url后面加上&per_page=3。(這個(gè)per_page是默認(rèn)的查詢字符,當(dāng)然你也可以用$config['query_string_segment']來(lái)自己設(shè)定)
因此c、d中的形式一般是為localhost/news?&per_page=2不過都一樣,沒什么影響。get的per_page還是3
*/
$config['first_link'] = '首頁(yè)'; // 第一頁(yè)顯示
$config['last_link'] = '末頁(yè)'; // 最后一頁(yè)顯示
$config['next_link'] = '下一頁(yè) >'; // 下一頁(yè)顯示
$config['prev_link'] = '< 上一頁(yè)'; // 上一頁(yè)顯示
$config['cur_tag_open'] = ' <a class="current">'; // 當(dāng)前頁(yè)開始樣式
$config['cur_tag_close'] = '</a>';
/*當(dāng)前頁(yè)結(jié)束樣式。這些你可以自己嘗試一下。
比如說我想讓當(dāng)前頁(yè)的分頁(yè)數(shù)字樣式好看一點(diǎn),紅色字體等。你就可以在current上加上css代碼
*/
$config['num_links'] = 2;// 當(dāng)前連接前后顯示頁(yè)碼個(gè)數(shù)。意思就是說你當(dāng)前頁(yè)是第5頁(yè),那么你可以看到3、4、5、6、7頁(yè)。
$config['uri_segment'] = 4;
/*這個(gè)是你在用a)、b)鏈接樣式的時(shí)候,用來(lái)判斷頁(yè)頁(yè)數(shù)。
比如localhost/news/page/3 這個(gè)uri_segment就要設(shè)定為3。localhost/news/title/page/3這個(gè)就要設(shè)定為4
*/
$config['use_page_numbers'] = TRUE;
/*這個(gè)就是a)、b)的差別了。開啟了,page就會(huì)表示頁(yè)數(shù)。false就會(huì)表示記錄數(shù)
*/
剛開始在網(wǎng)上查資料的時(shí)候,有很多這種寫法。
$this->model->get_news($config['per_page'],$this->uri->segment(3));
其實(shí)這種寫法就是針對(duì)b)這種連接形式的。這里的$this->uri->segment(3)就是取到page/20中的記錄數(shù)20。$config['per_page']就是限制輸出多少條。
有很大的局限性和誤導(dǎo)性。我開始就是死都不知道為什么這么寫。。后來(lái)才發(fā)現(xiàn),手冊(cè)才是最好的老師。
當(dāng)我們把CI分頁(yè)類的一些參數(shù)都配置好了之后,$this->pagination->initialize($config);//配置分頁(yè)
$page = $this->pagination->create_links(); //我們就得到了分頁(yè)了
直接傳遞到視圖頁(yè),即可。
至于怎么加載模型,怎么存取數(shù)據(jù)記錄,怎么傳遞變量到視圖,這里就不說了,看手冊(cè)好了。
忘記說了,帶查詢參數(shù)的分頁(yè),我是這么做的。視圖中將查詢參數(shù)get提交到控制器的search方法。在search中,用$get = $this->input->get();去獲取到查詢參數(shù)。
然后加載model,用帶查詢參數(shù)和分頁(yè)參數(shù)去讀取記錄,將結(jié)果顯示到視圖。。
另外還發(fā)現(xiàn)個(gè)小bug,比如/news/page/-1000這樣的時(shí)候,下面的分頁(yè)鏈接將會(huì)出現(xiàn)負(fù)值
發(fā)現(xiàn)system/libraries/Pagination.php代碼如下
if ($this->use_page_numbers AND $this->cur_page == 0)
{
$this->cur_page = $base_page;
}
//應(yīng)為
if ($this->use_page_numbers AND $this->cur_page <= 0)
{
$this->cur_page = $base_page;
}
才對(duì)吧,經(jīng)過修改后,這個(gè)問題沒有了。
- CI框架常用經(jīng)典操作類總結(jié)(路由,偽靜態(tài),分頁(yè),session,驗(yàn)證碼等)
- CI框架(ajax分頁(yè),全選,反選,不選,批量刪除)完整代碼詳解
- PHP CodeIgniter分頁(yè)實(shí)例及多條件查詢解決方案(推薦)
- CodeIgniter分頁(yè)類pagination使用方法示例
- codeigniter實(shí)現(xiàn)get分頁(yè)的方法
- Codeigniter框架實(shí)現(xiàn)獲取分頁(yè)數(shù)據(jù)和總條數(shù)的方法
- codeigniter中測(cè)試通過的分頁(yè)類示例
- CI框架簡(jiǎn)單分頁(yè)類用法示例
相關(guān)文章
Yii框架創(chuàng)建cronjob定時(shí)任務(wù)的方法分析
這篇文章主要介紹了Yii框架創(chuàng)建cronjob定時(shí)任務(wù)的方法,結(jié)合具體實(shí)例形式分析了Yii定時(shí)任務(wù)相關(guān)配置、實(shí)現(xiàn)步驟與注意事項(xiàng),需要的朋友可以參考下2017-05-05淺談laravel數(shù)據(jù)庫(kù)查詢返回的數(shù)據(jù)形式
今天小編就為大家分享一篇淺談laravel數(shù)據(jù)庫(kù)查詢返回的數(shù)據(jù)形式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧2019-10-10PHP中file_get_contents函數(shù)抓取https地址出錯(cuò)的解決方法(兩種方法)
本文通過兩種方法解決PHP中file_get_contents函數(shù)抓取https地址出錯(cuò),需要的朋友可以參考下2015-09-09php設(shè)計(jì)模式之狀態(tài)模式實(shí)例分析【星際爭(zhēng)霸游戲案例】
這篇文章主要介紹了php設(shè)計(jì)模式之狀態(tài)模式,結(jié)合星際爭(zhēng)霸游戲案例形式分析了php狀態(tài)模式相關(guān)原理、使用技巧與注意事項(xiàng),需要的朋友可以參考下2020-03-03