thinkPHP使用post方式查询时分页失效的解决方法


Posted in PHP onDecember 09, 2015

本文实例讲述了thinkPHP使用post方式查询时分页失效的解决方法。分享给大家供大家参考,具体如下:

昨天晚上一直没有解决的php项目中的bug,就在刚才终于搞定,在这里还需要感谢各位大神给的帮助!

具体问题描述

最近遇到一个非常棘手的问题,也是因为刚入手thinkphp。在做项目的过程中,因为需要非常多的查询条件,如果以get方式提交表单的话,会因为url长度限制而报错,所以必须使用post方式提交表单数据,但是在分页的过程中,遇到了问题,因为thinkphp自带的分页是以a标签的形式,进行下一页的,这样查询条件就没有传入后台,导致点击下一页的时候,出现空白。

查看了一下thinkphp官方手册,说了如果是POST方式查询,如何确保分页之后能够保持原先的查询条件呢,具体说明如下图所示:

thinkPHP使用post方式查询时分页失效的解决方法

但是我对手册有一处不解,既然是以通过a标签分页,这样$map(即查询条件参数)中的参数值是怎么传到后台的呢?我在网上也找到了了其他的一些方法,比如用$_REQUEST方式获得参数,说是包括了post和get方式的传值,但是thinkphp的分页是使用a标签来传参的这样的话,参数应该还是无法获得,尝试了几次,结果果然是失败的。还有其他的方法,看了一下都不靠谱。于是在昨晚在博问上提问了一下。有一位大神给我灵感,就是用js修改a标签的href属性。这样确实可以,然后我尝试了一直,终于解决了问题。

解决方法:

<html>
...
...
<body>
<form action="" id="form" method="POST">
....
....
</for>
...
...
<!--分页-->
<div class="Item hr" style="float:right;">
   <div class="current" id="pageBar">{$page}</div>
</div>
...
...
<script type="text/javascript">
  $(function(){
     // 分页(修改链接方法)
    $('#pageBar a').click(function(){ 
      var tmpHref = $(this).attr('href');
      tmpHref = tmpHref.replace(/\/selCon\//,"");
      $("#form").attr("action", tmpHref);
      $("#form").submit();
      return false; 
    });
  }
</script>
</body>
</html>

其中,selCon是form中的参数们,比如name='selCon.a',name='selCon.b'......
按照上面的方法解决了点击下一页的时候,查询参数无法传递的问题。但是我又发现了一个问题,也就是说当我们进入第二页之后,然后再改变查询条件,这时查询出来的结果不是从第一个开始,而是从第二页开始,所以我们这里还需要在查询的时候在js中把p参数(当前页码)设置为1,具体方法如下:

<script type="text/javascript">
  $(function(){
    //查询
    $("#selecting").click(function(){
      $("#form").attr("action", "__URL__/listDept/p/1");
      $("#form").submit();
    });
  }
</script>

希望本文所述对大家基于thinkPHP的php程序设计有所帮助。

PHP 相关文章推荐
PHP:风雨欲来 路在何方?
Oct 09 PHP
PHP实现Socket服务器的代码
Apr 03 PHP
Apache实现Web Server负载均衡详解(不考虑Session版)
Jul 05 PHP
php页码形式分页函数支持静态化地址及ajax分页
Mar 28 PHP
destoon公司主页模板风格的添加方法
Jun 20 PHP
php利用反射实现插件机制的方法
Mar 14 PHP
php实现过滤字符串中的中文和数字实例
Jul 29 PHP
YII Framework框架教程之日志用法详解
Mar 14 PHP
php curl上传、下载、https登陆实现代码
Jul 23 PHP
PHP+MySQL实现消息队列的方法分析
May 09 PHP
phpfpm的作用和用法
Oct 10 PHP
Docker 安装 PHP并与Nginx的部署实例讲解
Feb 27 PHP
分享php代码将360浏览器导出的favdb的sqlite数据库文件转换为html
Dec 09 #PHP
微信支付PHP SDK之微信公众号支付代码详解
Dec 09 #PHP
作为程序员必知的16个最佳PHP库
Dec 09 #PHP
学习php设计模式 php实现备忘录模式(Memento)
Dec 09 #PHP
学习php设计模式 php实现观察者模式(Observer)
Dec 09 #PHP
PHP判断手机是IOS还是Android
Dec 09 #PHP
PHP的Yii框架的常用日志操作总结
Dec 08 #PHP
You might like
微博短链接算法php版本实现代码
2012/09/15 PHP
YII中assets的使用示例
2014/07/31 PHP
PHP实现简单实用的分页类代码
2016/04/08 PHP
php用户密码加密算法分析【Discuz加密算法】
2016/10/12 PHP
PHP实现微信图片上传到服务器的方法示例
2017/06/29 PHP
基于Laravel实现的用户动态模块开发
2017/09/21 PHP
PHP封装的XML简单操作类完整实例
2017/11/13 PHP
Docker搭建自己的PHP开发环境
2018/02/24 PHP
phpQuery采集网页实现代码实例
2020/04/02 PHP
js类 from qq
2006/11/13 Javascript
JavaScript高级程序设计 扩展--关于动态原型
2010/11/09 Javascript
js URL参数的拼接方法比较
2012/02/15 Javascript
jquery ajax的success回调函数中实现按钮置灰倒计时
2013/11/19 Javascript
JavaScript中this的9种应用场景及三种复合应用场景
2015/09/12 Javascript
jquery实现触发时更新下拉列表内容的方法
2015/12/02 Javascript
微信小程序 倒计时组件实现代码
2016/10/24 Javascript
js实现兼容PC端和移动端滑块拖动选择数字效果
2017/02/16 Javascript
简易Vue评论框架的实现(父组件的实现)
2018/01/08 Javascript
vue路由切换之淡入淡出的简单实现
2019/10/31 Javascript
分享Angular http interceptors 拦截器使用(推荐)
2019/11/10 Javascript
layui table表格数据的新增,修改,删除,查询,双击获取行数据方式
2019/11/14 Javascript
一看就会的vuex实现登录验证(附案例)
2020/01/09 Javascript
node.JS的crypto加密模块使用方法详解(MD5,AES,Hmac,Diffie-Hellman加密)
2020/02/06 Javascript
BootStrap前端框架使用方法详解
2020/02/26 Javascript
Python的Django框架中使用SQLAlchemy操作数据库的教程
2016/06/02 Python
利用selenium 3.7和python3添加cookie模拟登陆的实现
2017/11/20 Python
在Python中如何传递任意数量的实参的示例代码
2019/03/21 Python
python利用xpath爬取网上数据并存储到django模型中
2021/02/26 Python
英国Zoro工具:手动工具,电动工具和个人防护用品
2016/11/02 全球购物
比利时网上药店: Drogisterij.net
2017/03/17 全球购物
美国尼曼百货官网:Neiman Marcus
2019/09/05 全球购物
作风转变心得体会
2014/09/02 职场文书
委托证明书
2014/09/17 职场文书
2015年行政助理工作总结
2015/04/30 职场文书
母亲去世追悼词
2015/06/23 职场文书
2015年幼儿园国庆节活动总结
2015/07/30 职场文书