加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

ruby-on-rails – Rails处理多条路线上可用的动作的方法

发布时间:2020-12-17 03:27:16 所属栏目:百科 来源:网络整理
导读:我有以下路线: resources :users do # List reviews made by user resources :reviews,:only = [ :index ]endresources :products do # List reviews by product,and provide :product_id for creation resources :reviews,:only = [ :index,:new,:create ]
我有以下路线:

resources :users do
  # List reviews made by user
  resources :reviews,:only => [ :index ]
end

resources :products do
  # List reviews by product,and provide :product_id for creation
  resources :reviews,:only => [ :index,:new,:create ]
end

# Other actions don't depend on other resources
resources :reviews,:except => [ :index,:create ]

一切看起来都正确,除了ReviewsController #index:

def index
  if params[:user_id]
    @reviews = Review.find_all_by_user_id params[:user_id]
  else
    @reviews = Review.find_all_by_product_id params[:product_id]
  end
  respond_with @reviews
end

我想知道是否有上述问题的标准解决方案,或者是否有更好的方法来做到这一点.

解决方法

你有什么是好的,但如果你想要你也可以使用两种不同的行动.这种方法应该可以让您以后更轻松地更改视图,并且更安全一些.

match '/products/:product_id/reviews' => 'reviews#product_index'
match '/users/:user_id/reviews' => 'reviews#user_index'

它还可以使您的控制器代码更清晰,更不容易受到/ products / 10 / reviews?user_id = 100这样的奇怪查询的影响,这会导致显示用户的评论而不是产品的评论.

def product_index
  @reviews = Review.find_all_by_product_id params[:product_id]
  respond_with @reviews
end

def user_index
  @reviews = Review.find_all_by_user_id params[:user_id]
  respond_with @reviews
end

另一种选择是使用不同的控制器:

match '/products/:product_id/reviews' => 'product_reviews#index'
match '/users/:user_id/reviews' => 'user_reviews#index'

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读