laravel-admin模型表格和详情展示关联数据

最近整一个后台管理系统,遇到这么个问题:需要在一个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;
        });

相比之前的版本,现在这个看起来就简洁很多了。

 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章