问题描述
|
我想根据我的Rails应用程序中的最新文章和评论创建活动供稿。它们是活动记录的两种不同类型(它们的表结构不同)。
理想情况下,我将能够创建文章和评论的混合数组,然后以相反的时间顺序显示它们。
因此,我可以弄清楚如何同时获取文章和评论的数组,然后将它们合并在一起并按created_at进行排序,但是我很确定,一旦我开始使用分页,那也将无法正常工作。
有什么方法可以创建像混合示波器那样的作用域吗?
对我来说,另一个问题是它可能是所有文章,可能是所有评论,也可能是两者之间的某种组合。因此,我不能只说我要接受最后15条文章和最后15条评论。
关于如何解决这个问题的任何想法?
解决方法
在完成此操作之前,我通过使用非规范化的
UserActivity
模型或具有与with2ѭ的belongs_to
多态关联的相似模型进行管理-可以是您要显示的任何内容类型(帖子,评论,投票,喜欢,等等...)。
然后,在创建要显示的任何实体时,您将触发一个Observer
,并在UserActivity
表中创建一行并带有指向该记录的链接。
然后,要显示该列表,您只需按created_at
降序查询UserActivity
排序,然后浏览多态activity_source
关联即可获取内容数据。然后,您将需要在视图模板中使用一些技巧来呈现评论和帖子,以及其他任何与众不同的地方。
例如。就像是...
user_activity.rb:
class UserActivity < ActiveRecord::Base
belongs_to :activity_source,:polymorphic => true
# awesomeness continues here...
end
comment.rb(发布/无论如何)
class Comment < ActiveRecord::Base
# comment awesomeness here...
end
activity_source_observer.rb
class ActivitySourceObserver < ActiveRecord::Observer
observe :comment,:post
def after_create(activity_source)
UserActivity.create!(
:user => activity_source.user,:activity_source_id => activity_source.id,:activity_source_type => activity_source.class.to_s,:created_at => activity_source.created_at,:updated_at => activity_source.updated_at)
end
def before_destroy(activity_source)
UserActivity.destroy_all(:activity_source_id => activity_source.id)
end
end
, 看看这个railscast。
然后,您可以分页15篇文章,并在app/views/articles/index
中可以执行以下操作:
- @articles.each do |article|
%tr
%td= article.body
%tr
%td= nested_comments article.comment.descendants.arrange(:order => :created_at,:limit => 15)
这假定以下关系:
#app/models/article.rb
has_one :comment # dummy root comment
#app/models/comment.rb
belongs_to :article
has_ancestry
然后,您可以在文章中添加评论,如下所示:
root_comment = @article.build_comment
root_comment.save
new_comment = root_comment.children.new
# add reply to new_comment
new_reply = new_comment.children.new
依此类推。