我正在为工作制作一个laravel应用程序,我需要加载所有的用户与他们的附加角色,没有任何嵌套的角色。我将本教程用于角色:https://medium.com/@ezp127/laravel-5-4-native-user-authentication-role-authorization-3dbae4049c8a。如果我在我的用户模型上使用public $with = ['roles'];,它会返回用户对象中的整个角色对象,我需要它只返回角色:‘role _name’;
/**
* set up eloquent between roles/user
*
* @return \Illuminate\Database\Eloquent\Relations\belongsToMany
*/
public function roles()
{
return $this->belongsToMany(Role::class);
}上面是我的用户模型,下面是我的角色模型来定义关系。
/**
* provides a many-to-many relationship to User model
*
* @return User::class
*/
public function users()
{
return $this->belongsToMany(User::class);
}我认为通过将其添加到用户模型中:
protected $appends = ['role_name'];
public function getRoleNameAttribute()
{
return $this->attribute['name'];
}它将返回所有内容,但它所做的只是在模型上创建一个role_name:'user_name';。因此,我想我意识到我访问的只是用户表,而不是DB中的角色表,但也不知道该做什么。任何帮助都将不胜感激。
发布于 2018-10-01 13:54:08
如果为了方便起见,需要直接从模型中访问角色名称,则应该引用实际的关系数据:
protected $appends = ['role_name'];
public function getRoleNameAttribute()
{
return $this->roles->pluck('name');
}这应该会将角色名称数组附加到用户模型中。这将是一个数组,因为角色似乎与User模型有着多到多的关系。
发布于 2018-10-01 13:56:27
问题是您要在$this->attributes['name']中返回getRoleNameAttribute。你想要role names,所以你可以做这样的事情:
如果您想要一个具有名称的数组:
return $this->roles()->pluck('name')如果要将名称作为字符串:
return array_implode(", ", $this->roles()->pluck('name')->toArray());https://stackoverflow.com/questions/52592457
复制相似问题