在 中批量处理数据集合
在 php 框架 laravel 中,查询构造器提供了强大的功能来处理数据集合。但它缺乏类似于 中 withattr 方法的功能,无法对数据集合的特定字段进行批量转换。
自实现方法
一种解决方案是自行实现一个方法。例如,以下代码可将 status 字段从数值转换为可读字符串:
立即学习“”;
<?php namespace 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 方法,在其中添加所需的转换。
<?php namespace appservices; use illuminatedatabaseeloquentmodel; use illuminatedatabaseeloquentcollection; class dataprocessservice extends model { protected static function boot() { parent::boot(); // 覆写 toarray 方法 static::observe(new dataprocessobserver); } }
登录后复制
观察者
<?php namespace 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; }); } } }
登录后复制
以上就是如何在 Laravel 中实现类似 ThinkPHP withAttr 的批量数据转换功能?的详细内容,更多请关注php中文网其它相关文章!