tp5 分页后,修改数据

TP5分页数据修改踩坑及解决方案
本文讲述了在使用TP5框架进行分页后,尝试修改数据时遇到的问题及解决过程。官方手册的解决方案无法解决问题,作者通过自己的实践,强调了两个关键步骤,希望对其他PHP开发者有所帮助。

今天做项目遇到分页后要对数据做统计的情况。直接进入正题吧。
对于paginate()分页后的数据直接进行修改报如下错误

 Indirect modification of overloaded element of think\paginator\driver\Layui has no effect

查手册,官方表示这样解决,

$list = Db::name('user')->where('status',1)->paginate()->each(function($item, $key){
$item['nickname'] = 'think';
return $item;
});

然并卵,经过官方手册之后报错,render未定义方法

PHP Fatal error:  Call to undefined method think\Collection::render()

结合网友经验,实际还是有人解决了的,但是重点不够突出,看了之后可能还是会踩坑。下面结合我的实际代码分享一下重点:

    	$user = Session::get('user_info');
        // 根据我的id查找我的好友
        $friendList = db('account')->alias('a')
                                   ->join('Member b','b.aid = a.id')
       
在 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、付费专栏及课程。

余额充值