一般在数据分页的时候需要获取当前页的数据和总条数,一般人是在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'] = ' '; // 当前页开始样式

$config['cur_tag_close'] = '';

/*当前页结束样式。这些你可以自己尝试一下。

比如说我想让当前页的分页数字样式好看一点,红色字体等。你就可以在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;

}

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

php中ci框架分页,Codeigniter(CI)框架分页函数及相关知识相关推荐

  1. [项目过程中所遇到的各种问题记录]编辑器篇——FCKeditor相关知识及各种常见使用问题...

    马上2010年就要结束了,所以这几天准备花点时间把这一年中在开发过程中遇到的问题及解决方案记录下来,以备日后使用,目前先规划了:编辑器篇(仅针对asp.net开发中的fckeditor).图表篇(wi ...

  2. ci mysql 转义,CI(CodeIgniter)框架中URL特殊字符处理与SQL注入隐患分析

    本文实例分析了CI(CodeIgniter)框架中URL特殊字符处理与SQL注入隐患.分享给大家供大家参考,具体如下: php CI框架中URL特殊字符有很多是不支持的,导致像c++,括号这些常用的分 ...

  3. ci php 框架视频教程,CodeIgniter 3 PHP开发框架视频教程

    本视频主要讲解了codeigniter3(ci3)框架的基本使用及其源代码的组织及执行过程 教程列表: CodeIgniter3(ci3)基础教程_01_CI简介_origin CodeIgniter ...

  4. php ci base url,CodeIgniter中base_url问题

    最近在开发中使用了CodeIgniter框架,感觉这个框架比较轻量级,相对其它框架比较灵活. 在使用中遇到了如下问题:我的环境是nginx+php-fpm+mysql+CodeIgniter2.01. ...

  5. php前后端分离的框架,如何使用CI框架实现框架前后端分离

    这篇文章主要介绍了CI框架实现框架前后端分离的方法,结合实例形式较为详细的分析了CI框架前后端分离的相关视图.控制器设置与扩展等操作技巧,需要的朋友可以参考下 本文实例分析了CI框架实现框架前后端分离 ...

  6. think php ajax分页,thinkPHP5框架实现基于ajax的分页功能示例

    本文实例讲述了thinkPHP5框架实现基于ajax的分页功能.分享给大家供大家参考,具体如下: 最近一个页面的选项卡又牵扯到ajax分页,所以研究了一下tp5的ajax分页使用方法 首先看一下tp5 ...

  7. 自动部署 管道 ci cd_自动化测试在CI CD管道中的作用

    自动部署 管道 ci cd 业界广泛采用的软件开发实践:持续集成和持续部署可确保良好地交付产品并经常交付. 常规代码提交需要常规/连续测试,而如果忽略它,则可能导致非弹性基础结构. 如何交付坚固的CI ...

  8. PCL中的OpenNI点云获取框架(OpenNI Grabber Framework in PCL)

    从PCL 1.0开始,PCL(三维点云处理库Point Cloud Library)提供了一个通用采集接口,这样可以方便地连接到不同的设备及其驱动.文件格式和其他数据源.PCL集成的第一个数据获取驱动 ...

  9. AndroidAnnotations开发框架在Eclipse中的搭建和使用以及框架实现的原理

    AndroidAnnotations是用来解决开发中繁琐的初始化组件的一个开源的框架,开发中只需要配置一下相应的注解标签就可以了,其他的工作AndroidAnnotations框架都会帮我们解决,是我 ...

最新文章

  1. 2022-2028年中国汽车内饰行业市场需求与投资规划分析报告
  2. 如何修改dedecms专题目录默认名称special
  3. 算法基础课-动态规划-区间dp-AcWing 282. 石子合并:区间dp
  4. 女生适不适学习Java编程
  5. webpack入门——构建简易版vue-cli
  6. linux就业技术指导,学linux前景怎么样
  7. 微信小程序|开发实战篇之七-steps进度条组件
  8. iPhone 12系列全新渲染图曝光:4个“杯型” 起售价可能不到5k
  9. c socket双向通信 qq linux,请问如何实现像QQ那样2个内网用户的点到点SOCKET通信?...
  10. Linux学习总结(34)——Linux系统目录结构详解
  11. linux yum仓库制作,yum仓库搭建之RPM包制作
  12. 单片机加减法计算器_单片机简易加法计算器程序
  13. qt 处理oracle事务,qt调用oracle存储过程,该怎么处理(2)
  14. clone,Duplicate复制target XCode iOS
  15. python自动抠图软件_比PS还好用!Python 20行代码批量抠图
  16. 怎么读取cf卡id_CF卡传输程序的步骤解析
  17. zui php,ZUI前端html5框架 php版 v1.9.1
  18. 面试时说上一家公司的离职原因
  19. 矩阵相抵的一道例题(对称+主子式)
  20. FPGA的NIOS-II开发入门

热门文章

  1. 淘汰过时的工具也有错?微软的 Blazor 框架会是下一个 SilverLight?
  2. Java 和 Python 并列第二、Julia 下滑,揭晓 RedMonk 最新编程语言榜单!
  3. 多人聊天、预约会议,FaceTime登录Windows和Android系统
  4. 苹果自研 M1 芯片性能强大,却不支持 Docker ?
  5. 《CSDN好师父》给你更好选择:“深圳工资、长沙房价、全球视野”
  6. 专访商汤联合创始人林达华:商汤的开源战略,从算法做起
  7. CDN/视频流成“风口”,2 年内实现规模商用,揭晓 2020 年边缘计算发展现状!...
  8. 漫画 | 如何获得关系数据库王国的永久居住权?
  9. 低代码的兴起:花更少的钱,赚更多的钱
  10. 远程办公一晃一天,环境搭建履步维艰