欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Codeigniter(CI)框架分頁函數(shù)及相關(guān)知識

 更新時間:2014年11月03日 09:02:56   投稿:hebedich  
文章主要介紹了一個自己封裝的Codeigniter(CI)框架的分頁函數(shù)以及Codeigniter(CI)框架分頁類的使用心得,非常簡單實用,希望對大家能有所幫助

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

復(fù)制代碼 代碼如下:

/**
     * 獲取分頁數(shù)據(jù)及總條數(shù)
     * @param string @tablename 表名
     * @param mixed $where 條件
     * @param int $limit 每頁條數(shù)
     * @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條記錄開始分頁,即頁面的第一條記錄,是數(shù)據(jù)庫中的第20條記錄。
c) localhost/news?per_page=2 第二頁
d) localhost/news?per_page=20 同b)

首先我們先看一下CI分頁的參數(shù):

復(fù)制代碼 代碼如下:

$config['base_url'] = $url;  
/* 分頁的基礎(chǔ) URL
如果你想用a、b的鏈接形式,則該url應(yīng)該形式如/news/page/ 
如果鏈接是c、d的形式,則url應(yīng)該如/news? 
*/ 
$config['total_rows'] = $total;//記錄總數(shù),這個沒什么好說的了,就是你從數(shù)據(jù)庫取得記錄總數(shù)  
$config['per_page'] = $pagesize; //每頁條數(shù)。額,這個也沒什么好說的。。自己設(shè)定。默認為10好像。  
$config['page_query_string'] = TRUE;  
/*傳參形式。開啟true則會自動在你的url后面加上&per_page=3。(這個per_page是默認的查詢字符,當然你也可以用$config['query_string_segment']來自己設(shè)定)
因此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>';  
/*當前頁結(jié)束樣式。這些你可以自己嘗試一下。
比如說我想讓當前頁的分頁數(shù)字樣式好看一點,紅色字體等。你就可以在current上加上css代碼 
*/ 
$config['num_links'] = 2;// 當前連接前后顯示頁碼個數(shù)。意思就是說你當前頁是第5頁,那么你可以看到3、4、5、6、7頁。  
$config['uri_segment'] = 4;  
/*這個是你在用a)、b)鏈接樣式的時候,用來判斷頁頁數(shù)。
比如localhost/news/page/3  這個uri_segment就要設(shè)定為3。localhost/news/title/page/3這個就要設(shè)定為4 
*/ 
$config['use_page_numbers'] = TRUE;  
/*這個就是a)、b)的差別了。開啟了,page就會表示頁數(shù)。false就會表示記錄數(shù)
*/ 

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

復(fù)制代碼 代碼如下:

$this->model->get_news($config['per_page'],$this->uri->segment(3)); 

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

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

復(fù)制代碼 代碼如下:

$page = $this->pagination->create_links();  //我們就得到了分頁了 

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

至于怎么加載模型,怎么存取數(shù)據(jù)記錄,怎么傳遞變量到視圖,這里就不說了,看手冊好了。

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

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

復(fù)制代碼 代碼如下:

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;  


才對吧,經(jīng)過修改后,這個問題沒有了。

相關(guān)文章

最新評論