class A
WHY = “I don’t know why!!”
def self.foo
WHY
end
end
puts A.instance_eval(“foo”)  # => I don’t know why!!
puts A.instance_eval(“WHY”)  # => uninitialized constant Class::WHY
(NameError)
class A
WHY = “I don’t know why!!”
def self.foo
WHY
end
end
puts A.instance_eval(“foo”)  # => I don’t know why!!
puts A.instance_eval(“WHY”)  # => uninitialized constant Class::WHY
(NameError)
Kyung won Cheon wrote:
class A
WHY = “I don’t know why!!”def self.foo
WHY
end
endputs A.instance_eval(“foo”) # => I don’t know why!!
puts A.instance_eval(“WHY”) # => uninitialized constant Class::WHY
(NameError)What’s difference?
Help Me^^
A.instance_eval { foo }  # => “I don’t know why!!”
A.instance_eval { constants }  # => [“WHY”]
A.instance_eval { const_get “WHY” }  # => “I don’t know why!!”
class A ; eval “WHY” ; end  # => “I don’t know why!!”
Constants follow different rules for lookup.
instance_eval changes the ‘self’ for method lookups, but you are still
in the top-level scope for constant lookups.  You must be inside “class
A” (or “module A”) to get the constant lookup of WHY == A::WHY.
Note the complementary case,
B = Class.new {
WHEREAMI = “here”
}
WHEREAMI # => “here”
Despite being defined inside the instance of B, this constant lies in
the top-level scope.
This forum is not affiliated to the Ruby language, Ruby on Rails framework, nor any Ruby applications discussed here.
Sponsor our Newsletter | Privacy Policy | Terms of Service | Remote Ruby Jobs