最近整一个后台管理系统,遇到这么个问题:需要在一个model的grid()和detail()方法中展示另一个model中的某个字段,但是只存了主键id,没存这个字段本身。
之前也遇到过这种问题,也解决了,但总觉得不够优雅。之前代码如下这种:
$grid->column('来源')->display(function() {
$user_info = User::where(['id' => $this->user_id])->first();
if ($user_info) {
$user_info = $user_info->toArray();
}
return isset($user_info['source']) ? $user_info['source'] : "";
});
思路很明确,但很繁琐。事实上可以在需要展示的model中定义一个user()方法,关联两个model:
public function user()
{
return $this->belongsTo(User::class, 'user_id');
}
然后在对应的grid()方法中这么写就可以了:
$grid->column('user.source', __('来源'));
注意,这里的user一定要和model中定义的user()方法名对应。同样,如果是在detail()方法中展示,可以这样:
$show->user('来源')->as(function ($user) {
return $user->source;
});
相比之前的版本,现在这个看起来就简洁很多了。