视图中的简单RoR关系

时间:2012-10-01 14:38:27

标签: ruby-on-rails devise

我正在研究Ruby on Rails,我正在尝试使用devise创建这个简单的博客系统来创建登录部分。

这个问题必须有一个非常简单的答案,但我找不到谷歌,所以我终于放弃了,决定在这里问。

我有一个由devise创建的Users表和一个由scaffold命令创建的Posts表。

Posts表有一个user_id字段。在创建帖子时,我使用以下代码:

  def create
    @post = Post.new(params[:post])
    @post.user_id = current_user.id

    respond_to do |format|
      if @post.save
        format.html { redirect_to @post, notice: 'Post was successfully created.' }
        format.json { render json: @post, status: :created, location: @post }
      else
        format.html { render action: "new" }
        format.json { render json: @post.errors, status: :unprocessable_entity }
      end
    end
  end

这样我就可以获得用户ID并创建这种关系。

这是我的帖子模型:

class Post < ActiveRecord::Base
  attr_accessible :body, :title, :user_id

  belongs_to :user

end

现在,我想要的只是在list方法中显示作者的名字。

我尝试了几件事,但似乎都没有完成任务。

如何将用户名链接到帖子而不是用户ID?

我当前的索引方法是标准方法:

  def index
    @posts = Post.all

    respond_to do |format|
      format.html # index.html.erb
      format.json { render json: @posts }
    end
  end

我知道我需要在Post.all中添加参数,但是如何?

谢谢!

注意:我使用rails 3和PostgreSQL。

2 个答案:

答案 0 :(得分:1)

您可以通过以下关系访问用户对象:

@post.user.name

如果您想加载关系,可以将@posts = Post.all语句更改为以下内容:

@posts = Post.includes(:user)

答案 1 :(得分:0)

假设用户名在User#name,您可以通过在视图中添加以下内容来显示:

<%= post.user.name %>

你的帖子/ index.html.erb视图可能有一些代码ala

<% @posts.each do |post| %>
  <tr>
    <td><%= post.name %></td>
    ...
  </tr>
<% end %>

使用作者姓名添加另一个表格单元格可能会显示如下:

<% @posts.each do |post| %>
  <tr>
    <td><%= post.name %></td>
    <td><%= post.user.name %></td>
  </tr>
<% end %>
相关问题