• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

Codeigniter(CI)框架分页函数及相关知识_PHP

php 搞代码 3年前 (2022-01-25) 14次浏览 已收录 0个评论

一般在数据分页的时候需要获取当前页的数据和总条数,一般人是在model中封装两个函数分别获取当前页的数据和数据总条数,业务逻辑类似,感觉有点冗余,可以封装在一起:

<br />/**<br />     * 获取分页数据及总条数<br />     * @param string @tablename 表名<br />     * @param mixed $where 条件<br />     * @param int $limit 每页条数<br />     * @param int $offset 当前页<br />     */<br />    public function get_page_data($tablename, $where, $limit, $offset, $order_by, $db)<br />    {<br />        if(empty($tablename))<br />        {<br />            return FALSE;<br />        }<br />        <br />        $dbhandle = empty($db) ? $this->db : $db;<br />        <br />        if($where)<br />        {<br />            if(is_array($where))<br />            {<br />                $dbhandle->where($where);<br />            }<br />            else<br />            {<br />                $dbhandle->where($where, NULL, false);<br />            }<br />        }<br />        <br />        $db = clone($dbhandle);<br />        $total = $dbhandle->count_all_results($tablename);<br />        <br />        if($limit)<br />        {<br />            $db->limit($limit);<br />        }<br />        <br />        if($offset)<br />        {<br />            $db->offset($offset);<br />        }<br />        <br />        if($order_by)<br />        {<br />            $db->order_by($order_by);<br />        }<br />        <br />        $data = $db->get($tablename)->result_array();<br />        <br />        return array('total' => $total, 'data' => $data);<br />    }<br />

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分页的参数:

<br />$config['base_url'] = $url;   <br />/* 分页的基础 URL<br />如果你想用a、b的链接形式,则该url应该形式如/news/page/  <br />如果链接是c、d的形式,则url应该如/news?  <br />*/  <br />$config['total_rows'] = $total;//记录总数,这个没什么好说的了,就是你从数据库取得记录总数   <br />$config['per_page'] = $pagesize; //每页条数。额,这个也没什么好说的。。自己设定。默认为10好像。   <br />$config['page_query_string'] = TRUE;   <br />/*传参形式。开启true则会自动在你的url后面加上&per_page=3。(这个per_page是默认的查询字符,当然你也可以用$config['query_string_segment']来自己设定)<br />因此c、d中的形式一般是为localhost/news?&per_page=2不过都一样,没什么影响。get的per_page还是3  <br />*/  <br />$config['first_link'] = '首页'; // 第一页显示   <br />$config['last_link'] = '末页'; // 最后一页显示   <br />$config['next_link'] = '下一页 >'; // 下一页显示   <br />$config['prev_link'] = '< 上一页'; // 上一页显示   <br />$config['cur_tag_open'] = ' '; // 当前页开始样式   <br />$config['cur_tag_close'] = '';   <br />/*当前页结束样式。这些你可以自己尝试一下。<br />比如说我想让当前页的分页数字样式好看一点,红色字体等。你就可以在current上加上css代码  <br />*/  <br />$config['num_links'] = 2;// 当前连接前后显示页码个数。意思就是说你当前页是第5页,那么你可以看到3、4、5、6、7页。   <br />$config['uri_segment'] = 4;   <br />/*这个是你在用a)、b)链接样式的时候,用来判断页页数。<br />比如localhost/news/page/3  这个uri_segment就要设定为3。localhost/news/title/page/3这个就要设定为4  <br />*/  <br />$config['use_page_numbers'] = TRUE;   <br />/*这<b>/本文来源gao@!dai!ma.com搞$$代^@码5网@</b><strong>搞代gaodaima码</strong>个就是a)、b)的差别了。开启了,page就会表示页数。false就会表示记录数<br />*/  <br />

刚开始在网上查资料的时候,有很多这种写法。

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

其实这种写法就是针对b)这种连接形式的。这里的$this->uri->segment(3)就是取到page/20中的记录数20。$config[‘per_page’]就是限制输出多少条。
有很大的局限性和误导性。我开始就是死都不知道为什么这么写。。后来才发现,手册才是最好的老师。

当我们把CI分页类的一些参数都配置好了之后,$this->pagination->initialize($config);//配置分页

<br />$page = $this->pagination->create_links();  //我们就得到了分页了  <br />

直接传递到视图页,即可。

至于怎么加载模型,怎么存取数据记录,怎么传递变量到视图,这里就不说了,看手册好了。

忘记说了,带查询参数的分页,我是这么做的。视图中将查询参数get提交到控制器的search方法。在search中,用$get = $this->input->get();去获取到查询参数。
然后加载model,用带查询参数和分页参数去读取记录,将结果显示到视图。。

另外还发现个小bug,比如/news/page/-1000这样的时候,下面的分页链接将会出现负值
发现system/libraries/Pagination.php代码如下

<br />if ($this->use_page_numbers AND $this->cur_page == 0)   <br />{   <br />    $this->cur_page = $base_page;   <br />}   <br />//应为   <br />if ($this->use_page_numbers AND $this->cur_page <= 0)   <br />{   <br />    $this->cur_page = $base_page;   <br />}  <br />

才对吧,经过修改后,这个问题没有了。


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:Codeigniter(CI)框架分页函数及相关知识_PHP

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址