thinkphp5分页点击下一页失效,查询带额外参数解决方法

最近在做项目时,遇到了一个问题,点击分类时带上参数id=3,查询出对应的产品,产品有一个分页,但是点击第二页的时候,

url变成了不带之前id参数的跳转,导致没有了查询条件,查询不出来商品,就去寻找解决方案。

 

首先看了看官方手册

分页参数

主要的分页参数如下:

参数描述
list_rows每页数量
page当前页
pathurl路径
queryurl额外参数
fragmenturl锚点
var_page分页变量
type分页类名

也可以在调用分页方法的时候传入,例如:

$list = Db::name('user')->where('status',1)->paginate(10,true,[
    'type'     => 'bootstrap',
    'var_page' => 'page',
]);

 paginate函数中有三个参数

/**
     * 分页查询
     * @param int|array $listRows 每页数量 数组表示配置参数
     * @param int|bool  $simple   是否简洁模式或者总记录数
     * @param array     $config   配置参数
     *                            page:当前页,
     *                            path:url路径,
     *                            query:url额外参数,
     *                            fragment:url锚点,
     *                            var_page:分页变量,
     *                            list_rows:每页数量
     *                            type:分页类名
     * @return \think\Paginator
     * @throws DbException
     */
    public function paginate($listRows = null, $simple = false, $config = [])

 然后在控制器中尝试

$cate_id  = $this->request->param('id');
$page = max(1,(int)input('get.page'));
$pageSize = 1;
$count = ProductIndex::where('p_cate_id',$cate_id)->count();

$pro_list = ProductIndex::where('p_cate_id',$cate_id)->paginate($pageSize,$count,['id'=>$cate_id ]); 

 没有效果,然后尝试 把参数写成['id'=>$_GET]还是不行,

最后参考这篇文章,https://blog.csdn.net/ylwsn21/article/details/76577668

改为了

$cate_id  = $this->request->param('id');
$page = max(1,(int)input('get.page'));
$pageSize = 1;
$count = ProductIndex::where('p_cate_id',$cate_id)->count();
$pro_list = ProductIndex::where('p_cate_id',$cate_id)->paginate($pageSize,$count,['query'=>$this->request->param() ]); 

就查询成功了,哦耶!

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当使用POST方式提交表单时,ThinkPHP默认使用 $_POST 变量来获取提交的数据,而 $_POST 是无法直接获取分页参数的,因此分页失效了。但是你可以使用 $_REQUEST 变量来获取提交的数据,它可以同时获取 GET 和 POST 的数据。具体的解决方法如下: 1. 修改控制器中的查询代码,使用 $_REQUEST 变量来获取提交的数据。 ```php public function index() { $pageSize = 10; $page = isset($_REQUEST['page']) ? intval($_REQUEST['page']) : 1; $where['name'] = isset($_REQUEST['name']) ? $_REQUEST['name'] : ''; $list = Db::name('user')->where($where)->paginate($pageSize, false, ['page' => $page]); $this->assign('list', $list); return $this->fetch(); } ``` 2. 修改模板中的分页代码,使用 $_REQUEST 变量来生成分页链接。 ```html <div class="page"> <ul> <?php if ($list->currentPage() > 1): ?> <li><a href="<?php echo url('/index', ['page' => $_REQUEST['page'] - 1]); ?>">上一页</a></li> <?php endif; ?> <?php for ($i = 1; $i <= $list->lastPage(); $i++): ?> <li <?php if ($list->currentPage() == $i): ?>class="active"<?php endif; ?>><a href="<?php echo url('/index', ['page' => $i]); ?>"><?php echo $i; ?></a></li> <?php endfor; ?> <?php if ($list->currentPage() < $list->lastPage()): ?> <li><a href="<?php echo url('/index', ['page' => $_REQUEST['page'] + 1]); ?>">下一页</a></li> <?php endif; ?> </ul> </div> ``` 通过这种方式,就可以在使用 POST 方式提交表单时,正确地生成分页链接,实现分页功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值