我正在使用三张桌子; HABTM设置中的用户,角色和roles_users。
我正在尝试向所有用户显示他们的角色。
user.rb模型
class User < ActiveRecord::Base
has_and_belongs_to_many :roles
# Include default devise modules. Others available are:
# :token_authenticatable, :confirmable,
# :lockable, :timeoutable and :omniauthable
devise :database_authenticatable, # :registerable,
:recoverable, :rememberable, :trackable, :validatable
# Setup accessible (or protected) attributes for your model
attr_accessible :email,:username, :password, :password_confirmation, :remember_me, :role_ids
# attr_accessible :title, :body
def role?(role)
return !!self.roles.find_by_name(role.to_s.camelize)
end
end
role.rb模型
class Role < ActiveRecord::Base
attr_accessible :role_name
has_and_belongs_to_many :users
end
users_controller.rb控制器
class UsersController < ApplicationController
# GET /users
# GET /users.xml
#load_and_authorize_resource
def index
# @user = User.find(params[:id])
#@user.roles
@users = User.all
@roles = Role.all
respond_to do |format|
format.html # index.html.erb
format.xml { render :xml => @users }
end
end
# GET /users/1
# GET /users/1.xml
def show
@user = User.find(params[:id])
respond_to do |format|
format.html # show.html.erb
format.xml { render :xml => @user }
end
end
我可以创建一个新用户并为他分配一个角色。我可以编辑用户并更改他的角色。我可以使用show来查看个人用户角色。
问题出在index.html.erb文件中,我试图显示所有用户及其角色。
这是代码。
../视图/用户/ index.html.erb
<table>
<tr>
<th>ID</th>
<th>Email</th>
<th>Username</th>
<th>Role </th>
<th>Role ID</th>>
</tr>
<% @users.each do |user| %>
<tr>
<td><%= user.id %></td>
<%= current_user = user.id %>
<td><%= user.email %></td>
<td><%= user.username %></td>
<td> <%= User.find(user.id).roles %> </td>
<td><%= link_to 'Show', user %></td>
<td><%= link_to 'Edit', edit_user_path(user) %></td>
<td><%= link_to 'Destroy', user, :confirm => 'Are you sure?', :method => :delete %></td>
</tr>
<% end %>
</table>
<br />
这会产生此输出:
john_user@nomail.com john [#<Role id: 1, role_name: "basic_user", created_at: "2012-12-06 18:03:43", updated_at: "2012-12-06 18:03:43">] Show Edit Destroy
所以它给了我整个Roles行而不仅仅是role_name。
我尝试了User.find(user.id).roles.role_name,User.find(user.id).roles [1]以及其他几种可能性,并且无法弄清楚如何只获取角色名称出现。
获得&#39; role_name&#39;的正确语法是什么?显示如下:
john_user@nomail.com john basic_user Show Edit Destroy
谢谢!
答案 0 :(得分:3)
您可以直接访问它:
<td> <%= user.roles.collect(&:name).join(",") %> </td>