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 相关文章推荐
Banner程序
Oct 09 PHP
PHP递归返回值时出现的问题解决办法
Feb 19 PHP
解析yii数据库的增删查改
Jun 20 PHP
CI(CodeIgniter)框架中的增删改查操作
Jun 10 PHP
ThinkPHP缓存方法S()概述
Jun 13 PHP
php实现的美国50个州选择列表实例
Apr 20 PHP
关于PHP开发的9条建议
Jul 27 PHP
PHP处理数组和XML之间的互相转换
Jun 02 PHP
PHP中in_array的隐式转换的解决方法
Mar 06 PHP
Yii支持多域名cors原理的实现
Dec 05 PHP
PHP PDOStatement::nextRowset讲解
Feb 01 PHP
PHP7 mongoDB扩展使用的方法分享
May 02 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获取url字符串截取路径的文件名和扩展名的函数
2010/01/22 PHP
php抓取页面与代码解析 推荐
2010/07/23 PHP
国外的为初学者写的JavaScript教程
2008/06/09 Javascript
jQuery 对象中的类数组操作
2009/04/27 Javascript
javascript event 事件解析
2011/01/31 Javascript
获取数组中最大最小值方法js代码(自写)
2013/08/12 Javascript
使用phantomjs进行网页抓取的实现代码
2014/09/29 Javascript
JS实现常见的TAB、弹出层效果(TAB标签,斑马线,遮罩层等)
2015/10/08 Javascript
Jquery ajax加载等待执行结束再继续执行下面代码操作
2015/11/24 Javascript
jQuery Mobile 和 Kendo UI 的比较
2016/05/05 Javascript
js放大镜放大购物图片效果
2017/01/18 Javascript
js+css3实现旋转效果
2017/01/20 Javascript
移动端触屏幻灯片图片切换插件idangerous swiper.js
2017/04/10 Javascript
微信小程序事件 bindtap bindinput代码实例
2019/08/26 Javascript
微信小程序后端实现授权登录
2020/02/24 Javascript
es6函数name属性功能与用法实例分析
2020/04/18 Javascript
Python的函数的一些高阶特性
2015/04/27 Python
Python黑魔法@property装饰器的使用技巧解析
2016/06/16 Python
用python做一个搜索引擎(Pylucene)的实例代码
2017/07/05 Python
对Python中DataFrame按照行遍历的方法
2018/04/08 Python
详解python Todo清单实战
2018/11/01 Python
浅谈Pandas:Series和DataFrame间的算术元素
2018/12/22 Python
详解Python列表赋值复制深拷贝及5种浅拷贝
2019/05/15 Python
Python提取视频中图片的示例(按帧、按秒)
2020/10/22 Python
MYPROTEIN澳大利亚官方网站:欧洲运动营养品牌
2019/06/26 全球购物
数据库连接池的工作原理
2012/09/26 面试题
应届生体育教师自荐信
2013/10/03 职场文书
部队学习十八大感言
2014/01/11 职场文书
社区综治宣传月活动总结
2014/07/02 职场文书
自主招生推荐信怎么写
2015/03/26 职场文书
2015年高校教师个人工作总结
2015/05/25 职场文书
感恩教育观后感
2015/06/17 职场文书
妇产科护理心得体会
2016/01/22 职场文书
导游词之珠海轮廓
2019/10/25 职场文书
关于python中模块和重载的问题
2021/11/02 Python
一文搞懂PHP中的抽象类和接口
2022/05/25 PHP