1

我正在使用三张桌子;HABTM 设置中的用户、角色和角色用户。

我正在尝试显示所有用户及其角色。

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 文件。

这是代码。

../views/users/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

所以它给了我整个角色行,而不仅仅是角色名称。

我已经尝试过 User.find(user.id).roles.role_name、User.find(user.id).roles[1] 和其他几种可能性,但无法弄清楚如何让角色名称只出现。

什么是正确的语法来显示“role_name”,如下所示:

john_user@nomail.com    john     basic_user        Show   Edit  Destroy

谢谢!

4

1 回答 1

3

您可以直接访问它:

<td> <%= user.roles.collect(&:name).join(",") %> </td>
于 2012-12-07T20:42:38.027 回答