草庐IT

ruby - 将属性方法委托(delegate)给父对象

我有以下类(class):classAlphabetattr_reader:letter_freqs,:statistic_letterdefinitialize(lang)@lang=langcaselangwhen:en@alphabet=('A'..'Z').to_a@letter_freqs={...}when:ru@alphabet=('А'..'Я').to_a.insert(6,'Ё')@letter_freqs={...}...end@statistic_letter=@letter_freqs.max_by{|k,v|v}[0]endendfoo=Alphabet.n

ruby-on-rails - 将方法委托(delegate)给 has_many 关联会忽略预加载

是否可以将方法委托(delegate)给Rails中的has_many关联,并且仍然将预加载的数据保存在该关联上,同时遵循得墨忒耳法则?目前在我看来,你被迫选择一个或另一个。也就是说:通过不委托(delegate)来保留预加载的数据,或者丢失预加载的数据和委托(delegate)。示例:我有以下两个模型:classUser注意:User#all_blogs_have_title?做的事情与all_have_title?的委托(delegate)方法完全相同。据我了解,以下内容违反了得墨忒耳定律。但是:它会保留您预加载的数据:user=User.includes(:blogs).firs

ruby-on-rails - Rails 委托(delegate)设置值

我有一个User.rb模型和一个UserSetting.rb模型,我想委托(delegate)给它们(getter和setter方法)。在user.rb中delegate:email_opt_in,:email_opt_in=,:to=>:user_setting乍一看效果很好。user=User.find(1)user.email_opt_in#=>falseuser.email_opt_in=trueuser.saveuser.email_opt_in#=>true但仔细观察,user.save不会传播到UserSetting模型。User.find(1).email_opt_in

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-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-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

javascript - 事件委托(delegate),Event.target 与 Event.currentTarget

在MDNEvent.targetreference有一个关于实现事件委托(delegate)的例子:事件委托(delegate)示例//Assumingthereisa'list'variablecontaininganinstanceofan//HTMLulelement.functionhide(e){//Unlesslistitemsareseparatedbyamargin,e.targetshouldbe//differentthane.currentTargete.target.style.visibility='hidden';}list.addEventListener