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 相关文章推荐
优化NFR之一 --MSSQL Hello Buffer Overflow
Oct 09 PHP
如何在PHP中使用Oracle数据库(4)
Oct 09 PHP
别人整理的服务器变量:$_SERVER
Oct 20 PHP
header导出Excel应用示例
Jan 24 PHP
php和jquery实现地图区域数据统计展示数据示例
Feb 12 PHP
PHP register_shutdown_function()函数的使用示例
Jun 23 PHP
zend framework重定向方法小结
May 28 PHP
Yii2 rbac权限控制之rule教程详解
Jun 23 PHP
php求今天、昨天、明天时间戳的简单实现方法
Jul 28 PHP
php和vue配合使用技巧和方法
May 09 PHP
php伪静态验证码不显示的解决方案
Sep 26 PHP
php回调函数处理数组操作示例
Apr 13 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遍历CSV类实例
2015/04/14 PHP
php实现处理输入转义字符的代码
2015/11/08 PHP
Laravel 5.5基于内置的Auth模块实现前后台登陆详解
2017/12/21 PHP
漂亮的仿flash菜单,来自蓝色经典
2006/06/26 Javascript
更优雅的事件触发兼容
2011/10/24 Javascript
javascript简单实现命名空间效果
2014/03/06 Javascript
正则表达式(语法篇推荐)
2016/06/24 Javascript
Angular下H5上传图片的方法(可多张上传)
2017/01/09 Javascript
详解vue-cli+es6引入es5写的js(两种方法)
2019/04/19 Javascript
详解微信小程序网络请求接口封装实例
2019/05/02 Javascript
php结合js实现多条件组合查询
2019/05/28 Javascript
layui实现根据table数据判断按钮显示情况的方法
2019/09/26 Javascript
Element Carousel 走马灯的具体实现
2020/07/26 Javascript
解决antd的Form组件setFieldsValue的警告问题
2020/10/29 Javascript
python 运算符 供重载参考
2009/06/11 Python
Flask SQLAlchemy一对一,一对多的使用方法实践
2013/02/10 Python
python实现在无须过多援引的情况下创建字典的方法
2014/09/25 Python
Django中几种重定向方法
2015/04/28 Python
Python中字符串的常见操作技巧总结
2016/07/28 Python
TF-IDF与余弦相似性的应用(一) 自动提取关键词
2017/12/21 Python
Python面向对象之继承原理与用法案例分析
2019/12/31 Python
30行Python代码实现高分辨率图像导航的方法
2020/05/22 Python
浅谈Python中文件夹和python package包的区别
2020/06/01 Python
python 合并多个excel中同名的sheet
2021/01/22 Python
网页布局中CSS样式无效的十个重要原因详解
2017/08/10 HTML / CSS
C++:局部变量能否和全局变量重名
2014/03/03 面试题
致裁判员加油稿
2014/02/08 职场文书
班主任班级寄语大全
2014/04/04 职场文书
大学生入党推荐书范文
2014/05/17 职场文书
会计求职信
2014/05/29 职场文书
我的中国梦演讲稿1000字
2014/08/19 职场文书
《伯牙绝弦》教学反思
2016/02/16 职场文书
如何使用php生成zip压缩包
2021/04/21 PHP
Ajax是什么?Ajax高级用法之Axios技术
2021/04/21 Javascript
MySQL三种方式实现递归查询
2022/04/18 MySQL
python神经网络学习 使用Keras进行回归运算
2022/05/04 Python