我将使用 StackOverflow 作为我的例子。假设我有一个 Question 模型。登录的用户可以“加星”一个 Question 以标记为他们的最爱之一。在数据库中,这种事情可能会存储在一个 UserQuestions 表中,其中包含一个 user_id 字段和一个 question_id 字段。这种功能不是典型的 CRUD,因为实际上只有“列表”、“添加”和“删除”。此外,显示在“用户已加星标的问题”列表中的记录不应是 UserQuestion 记录,而是 Question 记录。我应该在我的 Controller 和 UserQuestion 模型中放入什么代码?

class MyFavoriteQuestionsController < ApplicationController

  def index
    #list just the questions associated with current_user
  end

  def add
    #insert a row in the database for current_user and selected question
  def

  def remove
    #remove the row from the database
  end
end

最佳答案

如果你坚持惯例,我会说这是典型的垃圾。添加是创建,删除是销毁。

class FavouritesController < ApplicationController

  before_filter :find_user

  def index
    @favourites = @user.favourites
  end

  def create
    @question = Question.find params[:id]
    @user.favourites << @question
  def

  def destroy
    @favourite = @user.favourites.find_by_question_id params[:id]
    @favourite.destroy unless @favourite.blank?
  end
end


#routes.rb

resources :users do
  resources :favourites, :only => [:index, :create, :destroy]
end

#user.rb

has_many :user_favourites, :dependent => :destroy
has_many :favourites, :through => :user_favourites, :source => :question

关于ruby-on-rails - Ruby on Rails : How to model a "user favorite model",我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/7021026/

10-13 09:40