当前位置:  开发笔记 > 后端 > 正文

如何将参数传递给define_method?

如何解决《如何将参数传递给define_method?》经验,为你挑选了4个好方法。

我想将一个参数传递给使用define_method定义的方法,我该怎么做?



1> Kevin Conner..:

传递给define_method的块可以包含一些参数.这就是你定义的方法接受参数的方式.当你定义一个方法时,你真的只是在阻止该块并在类中保持对它的引用.参数随块一起提供.所以:

define_method(:say_hi) { |other| puts "Hi, " + other }



2> equivalent8..:

......如果你想要可选参数

 class Bar
   define_method(:foo) do |arg=nil|                  
     arg                                                                                          
   end   
 end

 a = Bar.new
 a.foo
 #=> nil
 a.foo 1
 # => 1

......尽可能多的争论

 class Bar
   define_method(:foo) do |*arg|                  
     arg                                                                                          
   end   
 end

 a = Bar.new
 a.foo
 #=> []
 a.foo 1
 # => [1]
 a.foo 1, 2 , 'AAA'
 # => [1, 2, 'AAA']

...的组合

 class Bar
   define_method(:foo) do |bubla,*arg|
     p bubla                  
     p arg                                                                                          
   end   
 end

 a = Bar.new
 a.foo
 #=> wrong number of arguments (0 for 1)
 a.foo 1
 # 1
 # []

 a.foo 1, 2 ,3 ,4
 # 1
 # [2,3,4]

... 他们都是

 class Bar
   define_method(:foo) do |variable1, variable2,*arg, &block|  
     p  variable1     
     p  variable2
     p  arg
     p  block.inspect                                                                              
   end   
 end
 a = Bar.new      
 a.foo :one, 'two', :three, 4, 5 do
   'six'
 end

更新

Ruby 2.0引入了双splat **(两颗星)(我引用):

Ruby 2.0引入了关键字参数,**的行为类似*,但是对于关键字参数.它返回一个带键/值对的哈希.

...当然你也可以在定义方法中使用它:)

 class Bar 
   define_method(:foo) do |variable1, variable2,*arg,**options, &block|
     p  variable1
     p  variable2
     p  arg
     p  options
     p  block.inspect
   end 
 end 
 a = Bar.new
 a.foo :one, 'two', :three, 4, 5, ruby: 'is awesome', foo: :bar do
   'six'
 end
# :one
# "two"
# [:three, 4, 5]
# {:ruby=>"is awesome", :foo=>:bar}

命名属性示例:

 class Bar
   define_method(:foo) do |variable1, color: 'blue', **other_options, &block|
     p  variable1
     p  color
     p  other_options
     p  block.inspect
   end
 end
 a = Bar.new
 a.foo :one, color: 'red', ruby: 'is awesome', foo: :bar do
   'six'
 end
# :one
# "red"
# {:ruby=>"is awesome", :foo=>:bar}

我试图用关键字参数创建示例,splat和double splat all in one:

 define_method(:foo) do |variable1, variable2,*arg, i_will_not: 'work', **options, &block|
    # ...

要么

 define_method(:foo) do |variable1, variable2, i_will_not: 'work', *arg, **options, &block|
    # ...

...但这不起作用,看起来有一个限制.当你认为它是有意义的,因为splat运算符是"捕获所有剩余的参数"而double splat是"捕获所有剩余的关键字参数",因此混合它们会破坏预期的逻辑.(我没有任何参考证明这一点doh!)

8月更新2018年:

摘要文章:https://blog.eq8.eu/til/metaprogramming-ruby-examples.html



3> Jörg W Mitta..:

除了Kevin Conner的回答:块参数不支持与方法参数相同的语义.您无法定义默认参数或块参数.

这只能在Ruby 1.9中使用新的替代"stabby lambda"语法修复,该语法支持完整方法参数语义.

例:

# Works
def meth(default = :foo, *splat, &block) puts 'Bar'; end

# Doesn't work
define_method :meth { |default = :foo, *splat, &block| puts 'Bar' }

# This works in Ruby 1.9 (modulo typos, I don't actually have it installed)
define_method :meth, ->(default = :foo, *splat, &block) { puts 'Bar' }


实际上,我相信define_method上的块参数确实支持splat,它也可以提供一种定义默认参数的循环方式.

4> akostadinov..:

使用2.2,您现在可以使用关键字参数:https: //robots.thoughtbot.com/ruby-2-keyword-arguments

define_method(:method) do |refresh: false|
  ..........
end

推荐阅读
农大军乐团_697
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有