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 相关文章推荐
第1次亲密接触PHP5(2)
Oct 09 PHP
无数据库的详细域名查询程序PHP版(2)
Oct 09 PHP
Win2003下APACHE+PHP5+MYSQL4+PHPMYADMIN 的简易安装配置
Nov 18 PHP
PHP4与PHP5的时间格式问题
Feb 17 PHP
PHP MemCached 高级缓存应用代码
Aug 05 PHP
详解PHP内置访问资源的超时时间 time_out file_get_contents read_file
Jun 03 PHP
php获得url参数中具有&amp;的值的方法
Mar 05 PHP
php使用number_format函数截取小数的方法分析
May 27 PHP
PHP 自动加载的简单实现(推荐)
Aug 12 PHP
PHP版单点登陆实现方案的实例
Nov 17 PHP
php实现留言板功能(代码详解)
Mar 28 PHP
laravel高级的Join语法详解以及使用Join多个条件
Oct 16 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学习之 循环结构实现代码
2011/06/09 PHP
php中try catch捕获异常实例详解
2014/11/21 PHP
windows环境下使用Composer安装ThinkPHP5
2018/05/18 PHP
JS获取并操作iframe中元素的方法
2013/03/21 Javascript
hover的用法及live的用法介绍(鼠标悬停效果)
2013/03/29 Javascript
快速查找数组中的某个元素并返回下标示例
2013/09/03 Javascript
js加载读取内容及显示与隐藏div示例
2014/02/13 Javascript
30个经典的jQuery代码开发技巧
2014/12/15 Javascript
js实现当前输入框高亮显示的方法
2015/08/19 Javascript
JavaScript如何实现对数字保留两位小数一位自动补零
2015/12/18 Javascript
Jquery调用iframe父页面中的元素及方法
2016/08/23 Javascript
Angular.js中用ng-repeat-start实现自定义显示
2016/10/18 Javascript
AngularJS动态加载模块和依赖的方法分析
2016/11/08 Javascript
Angular下H5上传图片的方法(可多张上传)
2017/01/09 Javascript
JavaScript引用类型Object常见用法实例分析
2018/08/08 Javascript
mock.js模拟前后台交互
2019/07/25 Javascript
vue-cli3+typescript新建一个项目的思路分析
2019/08/06 Javascript
微信公众号生成新浪短网址的实现(快速生成)
2019/08/18 Javascript
JS异步处理的进化史深入讲解
2019/08/25 Javascript
Javascript Web Worker使用过程解析
2020/03/16 Javascript
JS深入学习之数组对象排序操作示例
2020/05/01 Javascript
javascript实现打砖块小游戏(附完整源码)
2020/09/18 Javascript
Node使用koa2实现一个简单JWT鉴权的方法
2021/01/26 Javascript
解决Shell执行python文件,传参空格引起的问题
2018/10/30 Python
python实现汽车管理系统
2018/11/30 Python
django orm 通过related_name反向查询的方法
2018/12/15 Python
pytorch masked_fill报错的解决
2020/02/18 Python
Python正则表达式学习小例子
2020/03/03 Python
详解HTML5中的拖放事件(Drag 和 drop)
2016/11/14 HTML / CSS
记一次高分屏下canvas模糊问题
2020/02/17 HTML / CSS
科颜氏加拿大官方网站: Kiehl’s加拿大
2016/08/16 全球购物
优质美利奴羊毛袜,不只是徒步旅行:Darn Tough Vermont
2018/11/05 全球购物
党员弘扬焦裕禄精神思想汇报
2014/09/10 职场文书
开展党的群众路线教育实践活动工作总结
2014/11/05 职场文书
运动会通讯稿300字
2015/07/20 职场文书
任命书格式模板
2015/09/22 职场文书