如何加载所有模型中的所有关联

时间:2017-08-23 22:36:14

标签: ruby-on-rails

我正在建立一个简单的网站来学习RoR。它允许用户发布电影评论,但我想在我的根视图中实现一个链接,显示数据库中的所有评论。我怎么做?

我希望能够<%= link_to 'Reviews', reviews_path %>,但我的reviews#index URI模式为/movies/:movie_id/reviews

为了提取数据库中的所有评论,我应该在评论模型中添加什么内容?

我的评论控制器:

class ReviewsController < ApplicationController
  def create
    @movie = Movie.find(params[:movie_id])
    @review = @movie.reviews.create(review_params)
    redirect_to movies_path(@movie)
  end

  private
  def review_params
    params.require(:review).permit(:email, :comment)
  end

end

评论模型:

class Review < ApplicationRecord
  belongs_to :movie
end

我的根本观点:

<h3>All Reviews:</h3>
<!-- put link here -->
<h3>Sort By:</h3>
<p>
    <%= link_to 'Release', movies_path(:sort_param => "release") %>
    <%= link_to 'Title', movies_path(:sort_param => "title") %>
</p>

<h1>Popular Movies</h1>
<% @movies.each do |m| %>
   <h2>Title</h2>
   <%= m.title %>
   <%= m.release %>
   <%= link_to 'Show', movie_path(m) %>
<% end %>

编辑:我查看了this解决方案,但我不确定该代码放在何处。我试着把它放在Review的索引方法中,但是我收到了一个错误:

Couldn't find all Reviews with 'id': (all, {:order=>"created_at DESC", :limit=>10})

2 个答案:

答案 0 :(得分:0)

您只能在reviews文件中添加到routes.rb的路线。

resources :reviews, only: [:index]

答案 1 :(得分:0)

routes.rb

resources :reviews, only: [:index] 

<强> reviews_controller.rb

如果您想以最近的顺序显示来自任何电影的所有评论,您可以这样做:

class ReviewsController < ApplicationController

  def index
    @reviews = Review.order('created_at DESC').limit(10)
  end

  def create
    ...
  end

end