PHP前端开发

如何在 Laravel 中实现类似 ThinkPHP withAttr 的批量数据转换功能?

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

在 laravel 中批量处理数据集合

在 php 框架 laravel 中,查询构造器提供了强大的功能来处理数据集合。但它缺乏类似于 thinkphp 中 withattr 方法的功能,无法对数据集合的特定字段进行批量转换。

自实现方法

一种解决方案是自行实现一个方法。例如,以下代码可将 status 字段从数值转换为可读字符串:

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

<?phpnamespace apphelpers;use illuminatesupportcollection;class datacollectionhelper{    public static function withattr(collection $collection, array $attributes)    {        foreach ($collection as $item) {            foreach ($attributes as $field => $callback) {                $item->{$field} = $callback($item->{$field}, $item);            }        }        return $collection;    }}

使用此方法,您可以像这样对订单数据集合进行转换:

$orders = datacollectionhelper::withattr($orders, [    'status' => function($status) {        return ['待付款', '待发货'][$status];    }]);

修改内置方法

另一种方法是修改 laravel 内置的 toarray 方法。您可以创建一个新的模型或服务提供者,并覆写 toarray 方法,在其中添加所需的转换。

<?phpnamespace appservices;use illuminatedatabaseeloquentmodel;use illuminatedatabaseeloquentcollection;class dataprocessservice extends model{    protected static function boot()    {        parent::boot();        // 覆写 toarray 方法        static::observe(new dataprocessobserver);    }}

观察者

<?phpnamespace AppServices;use IlluminateDatabaseEloquentModel;use IlluminateSupportCollection;class DataProcessObserver{    public function updating(Model $model)    {        if ($model instanceof Collection) {            $model->transform(function ($item) {                $item->status = ['待付款', '待发货'][$item->status];                return $item;            });        }    }}