1

我想instance_eval上这堂课:

class A
  attr_reader :att
end

传递这个方法b

class B
  def b(*args)
    att
  end
end

但这正在发生:

a = A.new
bb = B.new
a.instance_eval(&bb.method(:b)) # NameError: undefined local variable or method `att' for #<B:0x007fb39ad0d568>

什么时候b是一个块它起作用,但b作为一种方法不起作用。我怎样才能让它工作?

4

2 回答 2

0

目前尚不清楚您的目标是什么。您可以通过在模块中定义方法并将模块包含在每个类中轻松地在类之间共享方法

module ABCommon
  def a
    'a'
  end
end

class A
  include ABCommon
end

Anything = Hash
class B < Anything
  include ABCommon

  def b(*args)
    a
  end

  def run
    puts b
  end
end
于 2013-04-24T17:00:49.177 回答
0

这个答案没有按照要求使用真正的方法,但我不需要返回 aProc或 change A。这是一个 DSL,def_b应该有一个对域有意义的名称,例如configure,并且它更有可能在模块或基类中定义。

class B
  class << self
    def def_b(&block)
      (@b_blocks ||= []) << block
    end

    def run
      return if @b_blocks.nil?
      a = A.new
      @b_blocks.each { |block| a.instance_eval(&block) }
    end
  end

  def_b do
    a
  end
end

它接受多个定义。它可以只接受一个像这样的定义:

class B
  class << self
    def def_b(&block)
      raise "b defined twice!" unless @b_block.nil?
      @b_block = block
    end

    def run
      A.new.instance_eval(&@b_block) unless @b_block.nil?
    end
  end

  def_b do
    a
  end
end
于 2013-05-03T11:55:09.963 回答