«

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

时间:2024-12-6 21:03     作者:emer     分类:


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

在laravel中,可以通过修改内置的toarray方法或自己实现一个新方法,实现类似于中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;
        }
    }
}
登录后复制

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

立即学习“”;

$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();
登录后复制

以上就是Laravel 查询构造器如何实现批量处理数据集合类似 ThinkPHP 中 withAttr 功能的效果?的详细内容,!