我有两种模式:
model User id:integer name:string
model Item id:integer name:string
什么是做功能的最佳方式:
所有用户都可以查看所有项目。当前用户可以“隐藏项目”。然后该项目未显示,但显示给没有隐藏项目的用户。
答案 0 :(得分:0)
您需要辅助模型来处理单个项目的“隐藏”逻辑。以下代码说明了如何使用子查询执行此操作:
class HiddenItem < ActiveRecord::Base
belongs_to :user
belongs_to :item
end
class Item < ActiveRecord::Base
has_many :hidden_items
def self.visible_for_user(user)
subquery = user.hidden_items.select("hidden_items.item_id").to_sql
where("items.id NOT IN (#{subquery})")
end
end
class User < ActiveRecord::Base
has_many :hidden_items
def visible_items
Item.visible_for_user(self)
end
end
现在您可以获取用户的非隐藏项目:
user = User.find(1)
user.visible_items
如果您想隐藏某个项目,可以执行以下操作:
user.hidden_items.create(item_id: item.id)