如何保持ActiveRecord关联DRY?

5 mysql activerecord dry

我有一个问题,试图在我的应用程序中保持AR finder DRY.我创建了一个博客应用程序,当用户第一次查看博客时,它会获取博客的所有相关页面,帖子,链接,标签和类别.Blog控制器的示例显示操作如下所示:

def show
    #find blog by user name
    @user= User.find_by_login(params[:id])
    @blog= @user.blog
    @posts = Post.status("publish",@user).find(:all, :order => "created_at DESC")
    @tags = @user.tags
    @pages = Page.status("publish",@user).find(:all, :order => "created_at DESC")
    @links = @user.links.public_link.find(:all, :order => 'created_at DESC')
    @archives = @posts.group_by(&:month)
    @categories = @user.categories.group_by(&:name)
    session[:found_user]=@user.login
    render :layout=>false
  end
Run Code Online (Sandbox Code Playgroud)

正如您所看到的,它不是很干,因为还有其他操作会在控制器中进一步调用相同的实例变量,例如@tags等.

我怎么能让这更干?我尝试将其移动到Blog模型中,但我仍然需要在控制器中调用各种实例变量,如@tags等.

有没有办法在首次调用博客时存储所有这些变量,并在控制器和操作中重用它们?

谢谢你的任何建议.我正在使用Rails 2.1

Fra*_*eil 3

我在博客上读到,只需用辅助方法替换之前的过滤器(或在控制器方法中加载各种数据)。像这样的东西:

class BlogsController < ApplicationController
  def show
    session[:found_user]=@user.login
    render :layout=>false
  end

  helper_method :user, :blog, :posts, :tags, :pages, :links, :archives, :categories

  protected
  def user
    @user ||= User.find_by_login(params[:id])
  end

  def blog
    @blog ||= user.blog
  end

  def posts
    @posts ||= Post.status("publish", user).find(:all, :order => "created_at DESC")
  end

  def tags
    @tags ||= user.tags
  end

  def pages
    @pages ||= Page.status("publish", user).find(:all, :order => "created_at DESC")
  end

  def links
    @links ||= user.links.public_link.find(:all, :order => 'created_at DESC')
  end

  def archives
    @archives ||= posts.group_by(&:month)
  end

  def categories
    @categories ||= user.categories.group_by(&:name)
  end
end

## app/views/blogs/show.html.erb
<p>Name: <%=h user.name %></p>
<h3><%= posts.length %> Posts</h3>
<% posts.each do |post| %>
  ...
<% end %>
<ul>
  <% categories.each do |category| %>
    <li><%=h category %></li>
  <% end %>
</ul>
Run Code Online (Sandbox Code Playgroud)

了解如何在视图中使用任何内容简单地调用数据库。此解决方案的优点是未调用的辅助方法不会占用操作时间。

如有必要,将辅助方法抽象为模块并将该模块包含在 ApplicationController 中。