当前位置:首页 > CMS教程 > 其它CMS > 列表

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

发布:smiling 来源: PHP粉丝网  添加日期:2021-04-21 10:47:59 浏览: 评论:0 

文章主要介绍了一个自己封装的Codeigniter(CI)框架的分页函数以及Codeigniter(CI)框架分页类的使用心得,非常简单实用,希望对大家能有所帮助。

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

  1. /** 
  2.      * 获取分页数据及总条数 
  3.      * @param string @tablename 表名 
  4.      * @param mixed $where 条件 
  5.      * @param int $limit 每页条数 
  6.      * @param int $offset 当前页 
  7.      */ 
  8.     public function get_page_data($tablename$where$limit$offset$order_by$db
  9.     { 
  10.         if(emptyempty($tablename)) 
  11.         { 
  12.             return FALSE; 
  13.         } 
  14.         
  15.         $dbhandle = emptyempty($db) ? $this->db : $db
  16.         
  17.         if($where
  18.         { 
  19.             if(is_array($where)) 
  20.             { 
  21.                 $dbhandle->where($where); 
  22.             } 
  23.             else 
  24.             { 
  25.                 $dbhandle->where($where, NULL, false); 
  26.             } 
  27.         } 
  28.         
  29.         $db = clone($dbhandle); 
  30.         $total = $dbhandle->count_all_results($tablename); 
  31.         
  32.         if($limit
  33.         { 
  34.             $db->limit($limit); 
  35.         } 
  36.         
  37.         if($offset
  38.         { 
  39.             $db->offset($offset); 
  40.         } 
  41.         
  42.         if($order_by
  43.         { 
  44.             $db->order_by($order_by); 
  45.         } 
  46.         
  47.         $data = $db->get($tablename)->result_array(); 
  48.         
  49.         return array('total' => $total'data' => $data); 
  50.     } 

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

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

刚开始在网上查资料的时候,有很多这种写法,代码如下:

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

  1. if ($this->use_page_numbers AND $this->cur_page == 0)   
  2. {   
  3.     $this->cur_page = $base_page;   
  4. }   
  5. //应为   
  6. if ($this->use_page_numbers AND $this->cur_page <= 0)   
  7. {   
  8.     $this->cur_page = $base_page;   
  9. }  

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

Tags: Codeigniter框架分页

分享到: