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

前端之家收集整理的这篇文章主要介绍了Codeigniter(CI)框架分页函数及相关知识前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

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

代码如下:
$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['prev_link'] = '< 上一页'; // 上一页显示 $config['cur_tag_open'] = '

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

代码如下:
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);//配置分页

代码如下:
pagination->create_links(); //我们就得到了分页

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

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

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

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

代码如下:
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; }

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

猜你在找的PHP相关文章