首页 > PHP资讯 > PHP培训技术 > ThinkPHP分页中带入查询(搜索)条件

ThinkPHP分页中带入查询(搜索)条件

PHP培训技术
查询条件分页

在上一小节《ThinkPHP
分页详解及分页应用实例》文中只讲述了普通查询分页的引用,其查询参数是相对固定的。很多情况下,分页还会带入查询条件,而这时查询往往是不固定的。例如常见的搜索,需要根据用户查询的关键字来进行检索,在搜索结果太多时,就需要将搜索结果进行合理分页。

ThinkPHP
分页可以很容易的实现对不固定查询参数的支持。具体实现是给分页类的 parameter
属性赋值或者直接实例化分页类时传入查询参数。下面以例子来说明。
parameter 属性赋值

例如要检索用户表中状态为 1
(status=1) 并且电子包含 163 的用户,当提交表单时(注意表单是 GET 方式提交),形成的 URL
地址大致如下:

http://www.phplo.com/index.php/Index/search/status/1/email/163

在搜索操作(search)中主要代码如下:




  1. public function search(){
  2. $Dao = M("User");
  3. // 构造查询条件
  4. $condition['status'] = $_GET['status'];
  5. $condition['email'] = array('like',"%".$_GET['email']."%");
  6. // 计算总数
  7. $count = $Dao->where($condition)->count();
  8. // 导入分页类
  9. import("ORG.Util.Page");
  10. // 实例化分页类
  11. $p = new Page($count, 10);
  12. // 获取查询参数
  13. $map['status'] = $_GET['status'];
  14. $map['email'] = $_GET['email'];
  15. foreach($map as $key=>$val) {
  16. $p->parameter .= "$key=".urlencode($val)."&";
  17. }
  18. // 分页显示输出
  19. $page = $p->show();

  20. // 当前页数据查询
  21. $list = $Dao->where($condition)->order('uid ASC')->limit($p->firstRow.','.$p->listRows)->select();

  22. // 赋值赋值
  23. $this->assign('page', $page);
  24. $this->assign('list', $list);

  25. $this->display();
  26. }

在页面的分页链接中,可以看到地址(如第 2
页)为:

http://www.phplo.com/index.php/Index/search/status/1/email/163?status=1&email=163&p=2

可以看见分页链接中已经包含了需要检索的
status=1&email=163
条件。当然,实际解析后的地址应该是:

http://www.phplo.com/index.php/Index/search/status/1/email/163/p/2/

这是因为
ThinkPHP 分页类对 URL 的处理还不够完美造成的。要对此进行改进,参看《ThinkPHP 定制分页风格及URL》。
传入 parameter
参数

带入查询条件的分页关键就是设置分页类的 parameter 属性值。除了上例中给 parameter
属性赋值外,也可以直接在实例化类的时候将 parameter 参数传入,两种方式结果是一致的:




  1. $parameter = 'status='.urlencode($_GET['status']).'&email='.urlencode($_GET['email']);
  2. // 实例化分页类时加入 parameter 参数
  3. $p = new Page($count, 10, $parameter);
  4. // 分页显示输出
  5. $page = $p->show();

提示

上述例子只是用于讲述分页中带入查询条件的使用,因此未对检索的关键字进行进行安全处理。实际使用中在进行查询之前,应对用户输入的关键词做安全性方面的处理。

PHP培训技术

本文由欣才IT学院整理发布,未经许可,禁止转载。
支持44不支持0