我使用Fractal laravel 包作为复杂数据输出的表示和转换层。
我写了一个UserTransformer
这样的:
public function transform(User $user)
{
return [
'user_id' => (int)$user->user_id,
'name' => $user->name,
'family' => $user->family,
'username' => $user->username,
'token' => $user->token,
'mobile' => $user->mobile,
'email' => $user->email,
'sex' => $user->sex,
'tel' => $user->tel,
'province' => $user->province,
'city' => $user->city,
'picture' => $user->picture,
'birthday' => $user->birthday,
'wedding_date' => $user->wedding_date,
'wife_birthday' => $user->wife_birthday,
'desc' => $user->desc,
'active' => (bool) $user->active,
'supervisor' => $user->supervisor,
'two_factor_enabled' => (bool) $user->two_factor_enabled,
'address' => $user->address,
'created_at' => $user->created_at,
];
}
现在在某些情况下,我想将User
模型的特定字段作为这样的集合返回:
public function index()
{
return $this->collection(User::get(['user_id','name','family','username','created_at']), new UserTransformer());
}
但在这种情况下,结果是这样的:
"result": [
{
"user_id": 1,
"name": "ahmad",
"family": "badpey",
"username": "09139616246",
"token": null,
"mobile": null,
"email": null,
"sex": null,
"tel": null,
"province": null,
"city": null,
"picture": null,
"birthday": null,
"wedding_date": null,
"wife_birthday": null,
"desc": null,
"active": false,
"supervisor": null,
"two_factor_enabled": false,
"address": null,
"created_at": {
"date": "2017-11-15 10:01:24.000000",
"timezone_type": 3,
"timezone": "Asia/Tehran"
}
}
]
如您所见,选择User
模型中未包含的字段具有null
值并返回。但我只想包含字段返回。我怎样才能做到这一点 ?