jjzjj

def_delegate

全部标签

ruby - 将实例方法委托(delegate)给类方法

在Ruby中,假设我有一个类Foo允许我对我的大量Foos进行分类。所有Foos都是绿色和球形的是自然界的基本法则,因此我定义了类方法如下:classFoodefself.colour"green"enddefself.is_spherical?trueendend这让我做Foo.colour#"green"但不是my_foo=Foo.newmy_foo.colour#Error!尽管my_foo显然是绿色的。显然,我可以定义一个调用self.class.colour的实例方法colour,但如果我有很多这样的基本特征,那将变得笨拙。我大概也可以通过定义method_missing来尝

ruby - `def +@` 和 `def -@` 是什么意思?

在此Haskell-likecomprehensionsimplementationinRuby有一些我在Ruby中从未见过的代码:classArraydef+@#implementationenddef-@#implementationendenddef+@和def-@是什么意思?在哪里可以找到关于它们的(半)官方信息? 最佳答案 它们是一元的+和-方法。当您编写-object或+object时会调用它们。例如,语法+x被替换为x.+@。考虑一下:classFoodef+(other_foo)puts'binary+'enddef

ruby-on-rails - 为什么在私有(private)部分中声明委托(delegate)方法时是公开的?

我可以通过将声明放在中使attr_reader(以及相关的attr_writer和attr_accessor)方法私有(private)私有(private)部分:classFooprivateattr_reader:bendFoo.new.b#=>NoMethodError:privatemethod`b'calledfor#但是,Rails的delegate和Ruby标准库的def_delegate不要这样工作。这些委托(delegate)方法始终是公共(public)的。classFooattr_reader:bdefinitialize@b='b'endendrequire'f

ruby - Rails 委托(delegate)方法如何工作?

在阅读了下面jvans的回答并多看了几次源代码之后,我现在明白了:)。如果有人仍然想知道Rails委托(delegate)的工作原理。Rails所做的只是在您运行委托(delegate)方法的文件/类中使用(module_eval)创建一个新方法。例如:classAdelegate:hello,:to=>:bendclassBdefhellophelloendend当委托(delegate)被调用时,rails将在类A中创建一个带有(*args,&block)的hello方法(从技术上讲,在类A写入的文件中),在该方法中,rails所做的一切都是使用“:到”值(它应该是一个对象或一个已

ruby - 将委托(delegate)方法设为私有(private)

我委托(delegate)了几个方法,还希望它们都是私有(private)的。classWalrusdelegate:+,:to=>:bubblesdefbubbles0endend我可以说private:+,但我必须为每个方法都这样做。有没有办法返回委托(delegate)方法列表或让委托(delegate)创建私有(private)方法? 最佳答案 因为delegate返回传入的符号列表,您可以像这样链接方法调用:private*delegate(:foo,:bar,:to=>:baz)

ruby-on-rails - 将模型上的所有方法调用委托(delegate)给关联

我有一个具有多态关联的ActiveRecord模型,如下所示:classReachtrueend这个模型就像一个代理。我需要做的是将对该对象的所有方法调用转发给关联的对象:reachable。我认为delegate在这里无济于事,因为我必须明确命名我需要委托(delegate)的所有方法。我需要像delegate:all这样的东西来委托(delegate)所有方法(不是all方法)。 最佳答案 从Rails5.1+开始,您可以委托(delegate)所有未使用delegate_missing_to:reachable实现的内容基本上

ruby - 裸星号作为方法定义中的参数 : def f(*)

我知道这是什么意思:deff(*args)...end但这意味着什么,为什么要使用它?它也可以与命名参数一起出现吗?deff(*)...end 最佳答案 deff(*)与deff(*args)具有相同的效果,只是它没有命名globbed参数数组。如果您希望函数接受任意数量的参数但实际上不需要在函数内引用它们,则可以使用它——例如,如果您重写一个方法但调用super而没有传递一个显式参数列表,这会导致将原始参数传递给super。您也可以编写deff(a,b,*)。 关于ruby-裸星号作为

Ruby 的 def 和 instance_eval 与 class_eval

我正在阅读ProgrammingRuby1.9的元编程部分,但我无法理解class_eval之间内部发生了什么|/class_exec与instance_eval/instance_exec.首先,我的理解是def在self的方法表中添加一个方法(类对象):classAputsself#=>Adeffoo;42;end#addedtothemethodtableofself,sobecomesaninstancemethodendA.new.foo#=>42如果我们使用class_eval,我们得到相同的行为:A.class_evaldoputsself#=>Adefbar;42;en

ruby-on-rails - 带有委托(delegate)和条件的事件记录

是否可以在您的ActiveRecord模型中使用委托(delegate)并在其上使用类似:if的条件?classUser:master,:if=>:has_master?belongs_to:master,:class_name=>"User"defhas_master?master.present?endend 最佳答案 不,你不能,但你可以传递:allow_nil=>true选项以在master为nil时返回nil。classUser:master,:allow_nil=>true#...enduser.master=nilus

ruby - Vim:突出显示 Ruby 中的关键字对(def/end、do/end 等)

InoneoftheEclipse-basededitorsthatItriedoutrecently(IthinkitwasRubyMine),whenaRubykeywordthateitheropenedorclosedamethodorblockwasselected,thecorrespondingopen/closekeywordwashighlighted.类似于Vim能够突出显示相应的开/关括号的方式。例如,如果我选择了“def”,它会突出显示相应的“end”。它也适用于do/endblock。这真的很方便,特别是对于那些很长且有时嵌套很重的Rspec文件。有人知道如何