我正在研究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。
答案 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 %>