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 相关文章推荐
用windows下编译过的eAccelerator for PHP 5.1.6实现php加速的使用方法
Sep 30 PHP
Excel数据导入Mysql数据库的实现代码
Jun 05 PHP
php pack与unpack 摸板字符字符含义
Oct 29 PHP
PHP 遍历文件实现代码
May 04 PHP
PHP生成自适应大小的缩略图类及使用方法分享
May 06 PHP
php实现汉字验证码和算式验证码的方法
Mar 07 PHP
typecho插件编写教程(三):保存配置
May 28 PHP
php通过前序遍历树实现无需递归的无限极分类
Jul 10 PHP
使用PHP如何实现高效安全的ftp服务器(一)
Dec 20 PHP
PHP Callable强制指定回调类型的方法
Aug 30 PHP
laravel5实现微信第三方登录功能
Dec 06 PHP
Laravel框架实现多个视图共享相同数据的方法详解
Jul 09 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中strtotime函数使用方法分享
2012/01/10 PHP
PHP中如何调用webservice的实例参考
2013/04/25 PHP
非常实用的php弹出错误警告函数扩展性强
2014/01/17 PHP
php采用session实现防止页面重复刷新
2015/12/24 PHP
js资料toString 方法
2007/03/13 Javascript
ppk谈JavaScript style属性
2008/10/10 Javascript
JavaScript字符串String和Array操作的有趣方法
2012/12/18 Javascript
javaScript让文本框内的最后一个文字的后面获得焦点实现代码
2013/01/06 Javascript
js格式化货币数据实现代码
2013/09/04 Javascript
浅析jquery的js图表组件highcharts
2014/03/06 Javascript
jQuery插件实现适用于移动端的地址选择器
2016/02/18 Javascript
学习Javascript闭包(Closure)知识
2016/08/07 Javascript
ReactNative-JS 调用原生方法实例代码
2016/10/08 Javascript
AngularJS表格添加序号的方法
2017/03/03 Javascript
jQuery插件FusionCharts绘制的3D饼状图效果实例【附demo源码下载】
2017/03/03 Javascript
Angular中实现树形结构视图实例代码
2017/05/05 Javascript
p5.js入门教程之平滑过渡(Easing)
2018/03/16 Javascript
解决vue接口数据赋值给data没有反应的问题
2018/08/27 Javascript
VUE-ElementUI 自定义Loading图操作
2020/11/11 Javascript
python实现2014火车票查询代码分享
2014/01/10 Python
用Python编写web API的教程
2015/04/30 Python
简单介绍Python中的round()方法
2015/05/15 Python
Python 查看list中是否含有某元素的方法
2018/06/27 Python
对numpy Array [: ,] 的取值方法详解
2018/07/02 Python
python numpy元素的区间查找方法
2018/11/14 Python
Python3.5内置模块之shelve模块、xml模块、configparser模块、hashlib、hmac模块用法分析
2019/04/27 Python
Python 使用list和tuple+条件判断详解
2019/07/30 Python
Jupyter notebook如何修改平台字体
2020/05/13 Python
Python matplotlib画图时图例说明(legend)放到图像外侧详解
2020/05/16 Python
django为Form生成的label标签添加class方式
2020/05/20 Python
Python3.8安装Pygame教程步骤详解
2020/08/14 Python
Lookfantastic日本官网:英国知名护肤、化妆品和头发护理购物网站
2018/04/21 全球购物
技术总监的工作职责
2013/11/13 职场文书
七年级生物教学反思
2014/01/30 职场文书
煤矿班组长竞聘书
2014/03/31 职场文书
2014班子成员自我剖析材料思想汇报
2014/10/01 职场文书