您的位置 >>> 星想互联 >>> 编程技术 >>> PHP高级编程
Thinkphp3.2.3中CURD方法盘点:page方法
点击数:1858  发布时间2017-10-15 18:30:04

page方法也是模型的连贯操作方法之一,是完全为分页查询而诞生的一个人性化操作方法。

用法

limit方法可用于分页查询,而page方法则是更人性化的进行分页查询的方法,以文章列表分页为例来说,如果使用limit方法,我们要查询第一页和第二页(假设我们每页输出10条数据)写法如下:

$Article = M('Article');

$Article->limit('0,10')->select(); // 查询第一页数据

$Article->limit('10,10')->select(); // 查询第二页数据

虽然利用扩展类库中的分页类Page可以自动计算出每个分页的limit参数,但是如果要自己写就比较费力了,如果用page方法来写则简单多了,例如:

$Article = M('Article');

$Article->page('1,10')->select(); // 查询第一页数据

$Article->page('2,10')->select(); // 查询第二页数据

显而易见的是,使用page方法你不需要计算每个分页数据的起始位置,page方法内部会自动计算。


3.1版本以后,page方法也支持2个参数的写法,例如:

$Article->page(1,10)->select();


page方法还可以和limit方法配合使用,例如:

$Article->limit(25)->page(3)->select();

当page方法只有一个值传入的时候,表示第几页,而limit方法则用于设置每页显示的数量,也就是说上面的写法等同于:

$Article->page('3,25')->select();

下面是一个分页实例:

 public function index(){
  $model=M('news');
  $where=array();
  $list=$model->where($where)->page($_GET['p'].',10')->select();
  $x=$model->where($where)->count();
  
  $page=new \Think\Page($x,10);
  
  foreach($list as $row){
   echo $row['id'].$row['title']."<br>";
  }
  
  echo $page->show();
}

来源:咸宁网站建设