Rails宝典七十六式:使用scope_out插件

本文介绍了Rails插件ScopeOut的安装与使用方法。该插件简化了模型中条件筛选的定义过程,提供了多种灵活的查找方式,如find_x、with_x及calculate_x等,并支持动态查找器和组合范围等功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

[b]安装[/b]
[code]
ruby script/plugin install http://scope-out-rails.googlecode.com/svn/trunk/
[/code]

[b]使用例子[/b]
[code]
# models/task.rb
scope_out :incomplete, :conditions => ['complete=?', false], :order => 'name'

# tasks_controller.rb
@tasks = Task.find_incomplete(:all)


# models/project.rb
has_many :tasks, :extend => Task::AssociationMethods

# projects_controller.rb
def show
@project = Project.find(params[:id])
@tasks = @project.tasks.find_incomplete(:all)
end
[/code]

[b]文档[/b]
[code]
=ScopeOut
Author:: John Andrews
License:: Distributes under the same terms as Ruby
============

==Usage:

class Person < ActiveRecord::Base
scope_out :women, :conditions => ["people.sex = ?", "F"]
end

The above code creates three class methods: find_women, with_women, and calculate_women.
It is equivalent to doing the following:

class Person < ActiveRecord::Base
def Person.with_women
with_scope :find => {:conditions => ['people.sex => ?', "F"]} do
yield
end
end

def Person.find_women(*args)
with_women {find(*args)}
end

def Person.calculate_women(*args)
with_women {calculate(*args)}
end
end

==with_x
Person.with_women acts just like with_scope, except the scope is already defined. For example:

Person.with_women do
Person.find(:all, :order => 'people.age desc')
end

==find_x
Person.find_women acts just like find, except that it is scoped with with_women:

Person.calculate_women(:first, :include => :pets)
# equivalent to Person.find(:first, :conditions => ["people.sex = ?", "F"], :include => :pets)

==calculate_x
Person.calculate_active (you guessed it) is exactly like Person.calculate, but scoped with 'with_women'

Person.calculate_active(:count, :all)
# is the same as Person.calculate(:count, :all, :conditions => ["person.sex = ?", "F"])

==Combined Scopes
You can use the combined_scope method to define a scope which is the combination of two or more scopes that you previously defined with scope_out.

class Ticket
scope_out :active
scope_out :johns_tickets, :conditions => {:assigned_to => 'John'}
combined_scope :todo_for_john, [:active, :johns_tickets]
end

==Association Finders
scope_out also creates a module called AssociationMethods inside the class that defines the scope. Using this, you can extend your associations using the same scopes. Let's define a second class:

class Person < ActiveRecord::Base
has_many :pets, :extend => Pet::AssociationMethods
scope_out :women, :conditions => ["people.sex = ?", "F"]
end

class Pet < ActiveRecord::Base
belongs_to :person
scope_out :cats, :conditions => ["pets.type = ?", "Feline"]
end

woman = Person.find_women(:first)
her_pets = woman.pets
her_cats = woman.pets.cats

# cats is cached on the association, so this doesn't cause another call to the database
# unless you do woman.pets.cats(:reload)
puts "Cat Lady!" if woman.pets.cats.length > 4

==Dynamic Finders
scope_out extends ActiveRecord::Base#method_missing to capture dynamic, scope-based finders.

female_centurions = Person.find_all_women_by_age(100)
scruffy = Pet.find_cats_by_name('Scruffy')

==Flexible Syntax
All of the following define the same scope:

class Ticket
scope_out :active
scope_out :active, :field => 'active', :value => true
scope_out :active, :conditions => ["active = ?", true]
scope_out :active, :conditions => {:active => true} # rails >= 1.2
end

Note: the :field, :value syntax will be deprecated in the near future in favor of the :conditions hash.

==Dynamic Conditions
If you want to use a dynamic condition (which will be evaluated each time the scope is called), you can pass the options hash as a block.

class Person < ActiveRecord::Base
scope_out :adults do
{:conditions => ['people.birthdate < ?', 18.years.ago],
:order => 'people.birthdate asc' }
end
end
[/code]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值