PHP前端开发

Laravel 查询构造器如何实现批量处理数据集合类似 ThinkPHP 中 withAttr 功能的效果?

百变鹏仔 1个月前 (12-15) #PHP
文章标签 批量

laravel查询构造器中批量处理数据集合

在laravel中,可以通过修改内置的toarray方法或自己实现一个新方法,实现类似于thinkphp中withattr功能的效果。

自定义方法

namespace app {    ...        class customcollection extends collection    {        // ...其他方法        public function toarray(callable $callback = null)        {            $toarray = $this->items;            if ($callback !== null) {                $toarray = array_map($callback, $toarray);            }                        // ...其他逻辑            return $toarray;        }    }}

然后在查询构造器中使用自定义方法:

立即学习“PHP免费学习笔记(深入)”;

$orders = db::table('orders')    ->select('*')    ->toarray(function ($order) {        $order['status'] = ['待付款', '待发货'][$order['status']];        return $order;    });

修改toarray方法

另一种方法是直接修改toarray方法:

use illuminatesupportcollection;collection::macro('customtoarray', function () {    $toarray = $this->items;    foreach ($toarray as &$order) {        $order['status'] = ['待付款', '待发货'][$order['status']];    }        // ...其他逻辑    return $toarray;});

然后在查询构造器中使用:

$orders = DB::table('orders')    ->select('*')    ->customToArray();