我正在建立一个简单的网站来学习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})
答案 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