tp5 分页后,修改数据 ( 2 )

本文介绍了在ThinkPHP5中如何更简便地修改分页后的数据,相较于之前的数组转换方法,本文推荐使用`each`方法。由于TP5.0的`each`存在bug,需要在`thinkCollection.php`中修改`each`方法。在TP5.1及以后的版本中,此问题已修正。通过阅读官方文档和论坛,可以更好地理解和操作分页数据。

为什么说这是2呢,因为之前我有写过一篇 同样是tp5分页后的数据修改的文章,请参考 https://blog.youkuaiyun.com/qq_39702981/article/details/104854741
这次是采用了更加简便的方法,其实具体官方文档也有,只是官方5.0有些bug,楼主在此补充说明一下。此次补充参照tp官方论坛,非楼主发现的bug。

描述
看过之前写的那一篇的都知道,那种方法是采用 将paginate() 之后的数据 转成数组赋值给一个新的数组,然后foreach 这个新数组来修改,这样修改起来篇幅比较长,而且不好理解。所以还是老实使用官方的each来修改, 注意,tp5.0 的each 循环有bug,并不能实际修改或增加 paginate 分页后的对象数据,所以:

第一步:找到 \thinkphp\library\think\Collection.php 下面定义的 each 方法
 

    /**
     * 给每个元素执行个回调
     *
     * @param  callable $callback
     * @return $this
     */
    public function each(callable $callback)
    {
        foreach ($this->items as $key => $item) {
            if ($callback($item, $key) === false) {
            
ThinkPHP5 中,`limit` 和 `paginate` 是用于分页查询的两种方法,但它们的功能和使用场景存在显著差异。 ### `limit` 方法 `limit` 方法主要用于限制查询结果返回的记录数量。它可以接受一个或两个参数,分别表示偏移量和获取的数量。例如: ```php $list = Db::name('user')->where('status', 1)->limit(10)->select(); ``` 上述代码表示从数据库中查询 `status` 字段为 `1` 的记录,并限制返回前 10 条数据。此方法适合手动控制分页逻辑,需要开发者自行计算偏移量并拼接分页参数[^1]。 ### `paginate` 方法 `paginate` 方法是专门为分页查询设计的封装方法,它会自动处理分页逻辑,并返回包含分页信息的对象。该方法支持多种配置方式,包括指定每页显示的记录数、自定义分页类等。例如: ```php $list = Db::name('user')->where('status', 1)->paginate(10); ``` 此代码表示从数据库中查询 `status` 字段为 `1` 的记录,并按照每页 10 条数据进行分页。`paginate` 返回的结果是一个对象,包含了当前页的数据以及分页信息(如总记录数、总页数等),非常适合直接用于前端展示分页导航[^1]。 ### 主要区别 1. **功能复杂度**:`limit` 只能限制查询结果的数量,而 `paginate` 不仅可以限制数量,还能自动生成分页导航信息。 2. **返回类型**:`limit` 返回的是二维数组,而 `paginate` 返回的是一个包含分页信息的对象。 3. **配置灵活性**:`paginate` 支持更多的配置选项,如自定义分页类、变量名等,可以通过传入配置数组实现更灵活的分页效果[^1]。 ### 示例代码 以下是使用 `paginate` 方法的完整示例: ```php $list = Db::name('user')->where('status', 1)->order('id', 'desc')->paginate(10, true, [ 'type' => 'bootstrap', 'var_page' => 'page', ]); ``` 这段代码不仅实现了分页查询,还指定了分页样式为 `bootstrap`,并且设置了分页变量名为 `page`[^1]。 ### 数据处理 此外,`paginate` 还支持在分页后对数据进行遍历处理,方便修改分页后的数据。例如: ```php $list = Db::name('user')->where('status', 1)->order('id', 'desc')->paginate()->each(function($item, $key) { $item['nickname'] = 'think'; return $item; }); ``` 这段代码展示了如何在分页后对每条数据进行处理,动态添加 `nickname` 字段[^2]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值