Rails 3,HABTM和显示数据

时间:2012-12-07 20:40:11

标签: ruby-on-rails ruby-on-rails-3 has-and-belongs-to-many

我正在使用三张桌子; 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

谢谢!

1 个答案:

答案 0 :(得分:3)

您可以直接访问它:

<td> <%= user.roles.collect(&:name).join(",") %> </td>