草庐IT

exec_proc

全部标签

ruby - 模块嵌套在 instance_eval/exec 或 module_eval/exec 中

我在尝试回答this时想到了这个问题.以下是预期的行为:moduleApModule.nestingend#=>[A]但是以下内容:A.instance_eval{pModule.nesting}A.instance_exec{pModule.nesting}A.module_eval{pModule.nesting}A.module_exec{pModule.nesting}全部返回[]。为什么这些不能像上面那样工作?附加问题Muistooshort提出了一个有趣的观点。如果这是正确的,那么Module.nesting将是依赖于文字上下文的方法和变量之一,例如Method#sourc

Ruby:在将 proc 转换为 block 时提供参数

我们可以很容易地定义一个方法并将它变成带有一元符号的block。defmy_method(arg)putsarg*2end['foo','bar'].each(&method(:my_method))#foofoo#barbar#ormy_method=->(arg){putsarg*2}['foo','bar'].each(&my_method)#sameoutput正如我们所见,当我们使用聚合时,第一个参数会自动传递。但是,如果我们需要传递2个或更多参数怎么办?my_method=->(arg,num){putsarg*num}['foo','bar'].each(&my_meth

ruby-on-rails - Ruby to_proc 破解与绑定(bind)

我正在尝试创建一个小的Rubyhack来制作类似于Symbol#to_prochack的反向操作。而Symbol#to_prochack使这成为可能:some_array.each(&:some_method)与相同some_array.each{|obj|obj.some_method}我想让这成为可能:some_array.each(&[:some_method])会和一样some_array.each{|obj|some_method(obj)}问题在于,除非some_method是内核方法,否则它的真正含义是:some_array.each{|obj|self.some_met

ruby-on-rails - Rails - ActionView::Base.field_error_proc 向上移动 DOM 树?

有没有办法从传入的html_tag元素向上攀登DOM树?ActionView::Base.field_error_proc=Proc.newdo|html_tag,instance|#implementationend无论如何我可以实现这个方法来向上移动DOM树并将一个类放在父div上吗?例如:EmailAddress我想在div.email上放置一个类,而不是直接在输入/标签上放置一些东西。这可以用field_error_proc方法完成还是有一个干净的替代方法?我想避免在我对每个表单字段的View中明确地这样做。(像下面这样).email{:class=>object.errors

ruby - procs 可以与 Ruby 2.0 中的 case 语句一起使用吗?

我记得在Ruby2.0的case语句中允许使用procs,但我无法用google搜索它。我尝试检查Ruby2.0.0NEWS和HowtowriteaswitchstatementinRuby.我还访问了http://ruby-doc.org,但它的关键字链接是针对Ruby1.9,而不是Ruby2.0。case语句中是否允许proc? 最佳答案 是的。2.0.0p0:001>lamb=->(x){x%2==1}#=>#2.0.0p0:002>case3;whenlambthenp(:yay);end:yay#=>:yay2.0.0p0

ruby - 通过方法调用时如何将参数传递给proc?

proc=Proc.newdo|name|puts"Thankyou#{name}!"enddefthankyieldendproc.call#outputnothing,justfineproc.call('God')#=>ThankyouGod!thank&proc#outputnothing,too.Fine;thank&proc('God')#Error!thank&proc.call('God')#Error!thankproc.call('God')#Error!#So,whatshouldIdoifIhavetopassthe'God'totheprocandusethe

ruby-on-rails - 在你的命令前加上 `bundle exec` 可能会解决这个问题

我在将网站部署到AWS时遇到问题。Gem::LoadError:Youhavealreadyactivatedrake10.4.2,butyourGemfilerequiresrake10.5.0.Prepending`bundleexec`toyourcommandmaysolvethis./var/app/ondeck/config/boot.rb:3:in`'/var/app/ondeck/config/application.rb:1:in`'/var/app/ondeck/Rakefile:4:in`'LoadError:cannotloadsuchfile--bundler

Ruby:如何获取可选 proc 参数的默认值

假设我有一个像这样的proc/lambda/block/method/etc:2.1.2:075>procedure=Proc.new{|a,b=2,*c,&d|42}=>#我知道我可以通过以下方式找出参数的名称:2.1.2:080>procedure.parameters=>[[:opt,:a],[:opt,:b],[:rest,:c],[:block,:d]]但是,如果给定的可选参数未给定,我该如何获取该可选参数的值呢?附言:是的。我知道这在here之前已经被问过/回答过,但之前的解决方案需要使用merbgem,这实际上有点误导。merb本身依赖于methoparagem(除非您使

ruby - 传递给 `instance_exec` 时如何执行 proc

问题的灵感来自thisone.Proc::new有一个选项可以在方法内部没有block的情况下调用:Proc::newmaybecalledwithoutablockonlywithinamethodwithanattachedblock,inwhichcasethatblockisconvertedtotheProcobject.当proc/lambda实例作为代码块传递时,将创建Proc的新实例:Proc.singleton_class.prepend(Module.newdodefnew(*args,&cb)puts"PROC#{[block_given?,cb,*args].i

ruby - 方法和 proc 对象有什么区别?

我知道Ruby中的方法不是对象,但proc和lambda才是。除此之外,它们之间还有什么区别吗?因为我们都可以绕过。是什么让proc对象与方法不同?方法:1.8.7-p334:017>defa_method(a,b)1.8.7-p334:018?>puts"amethodwithargs:#{a},#{b}"1.8.7-p334:019?>end1.8.7-p334:021>meth_ref=Object.method("a_method")=>#1.8.7-p334:022>meth_ref.call(2,3)过程对象:a=lambda{|a,b|puts"#{a},#{b}"}a.