ThinkPHP 分页中带入查询(搜索)条件
ThinkPHP 分页可以很容易的实现对不固定查询参数的支持。具体实现是给分页类的 parameter 属性赋值或者直接实例化分页类时传入查询参数。下面以例子来说明。
parameter 属性赋值
例如要检索用户表中状态为 1 (status=1) 并且电子包含 163 的用户,当提交表单时(注意表单是 GET 方式提交),形成的 URL 地址大致如下:
http://localhost/index.php/Index/search/status/1/email/163
在搜索操作(search)中主要代码如下:
public function search(){ $Dao = M("User"); // 构造查询条件 $condition['status'] = $_GET['status']; $condition['email'] = array('like',"%".$_GET['email']."%"); // 计算总数 $count = $Dao->where($condition)->count(); // 导入分页类 import("ORG.Util.Page"); // 实例化分页类 $p = new Page($count, 10); // 获取查询参数 $map['status'] = $_GET['status']; $map['email'] = $_GET['email']; foreach($map as $key=>$val) { $p->parameter .= "$key=".urlencode($val)."&"; } // 分页显示输出 $page = $p->show(); // 当前页数据查询 $list = $Dao->where($condition)->order('uid ASC')->limit($p->firstRow.','.$p->listRows)->select(); // 赋值赋值 $this->assign('page', $page); $this->assign('list', $list); $this->display(); }
在页面的分页链接中,可以看到地址(如第 2 页)为:
http://localhost/index.php/Index/search/status/1/email/163?status=1&email=163&p=2
可以看见分页链接中已经包含了需要检索的 status=1&email=163 条件。当然,实际解析后的地址应该是:
http://localhost/index.php/Index/search/status/1/email/163/p/2/
这是因为 ThinkPHP 分页类对 URL 的处理还不够完美造成的。要对此进行改进,参看《ThinkPHP 定制分页风格及URL》。
传入 parameter 参数
带入查询条件的分页关键就是设置分页类的 parameter 属性值。除了上例中给 parameter 属性赋值外,也可以直接在实例化类的时候将 parameter 参数传入,两种方式结果是一致的:
$parameter = 'status='.urlencode($_GET['status']).'&email='.urlencode($_GET['email']); // 实例化分页类时加入 parameter 参数 $p = new Page($count, 10, $parameter); // 分页显示输出 $page = $p->show();
提示
上述例子只是用于讲述分页中带入查询条件的使用,因此未对检索的关键字进行进行安全处理。实际使用中在进行查询之前,应对用户输入的关键词做安全性方面的处理。
本文属原创,转载请注明原文:http://www.zhimatong.com/jiaocheng/606.html
为保证教程的实用性及扩大知识面覆盖,如果您有相似问题而未解决,可联系在线客服免费技术支持。
热门主题
相关阅读
- ThinkPHP 5.1 缓存的创建与读取
- ThinkPHP5 查询本年、本月、本周的方法
- ThinkPHP使用update函数更新数据的方法
- ThinkPHP6多应用下路由设置
- ThinkPHP5.1图片上传后自定义图片名称和图片存储路径
- ThinkPHP页面提示Warning: require(): open_basedir restriction in effect. File的解决方法
- 中国数据API返回字符串true,判断不起作用的解决方法
- tp5中mysql查询select结果去重显示唯一数据的方法
- ThinkpPHP5.1表单多选checkbox的判断和保存传值
- thinkphp前端页面输出html
- vuejs和thinkphp结合的2种方法
- tp5.1 随机查询数据