草庐IT

Self-Healing

全部标签

ruby-on-rails - 在模型中使用 self.attribute 和 attribute 有什么区别?

在RubyonRails中,在模型中使用self.attribute和attribute有什么区别?在此示例中,假设my_attr是存储在数据库中的用户属性。classUser 最佳答案 您的示例的不同之处在于第一个有效,第二个无效。您的第二个版本没有做任何事情(至少没有任何意义)。编写my_attr=123不等同于self.my_attr=123。相反,它会创建一个名为my_attr的局部变量并将其设置为123,然后立即到达方法的末尾并丢弃my_attr。整个方法本质上是一个no-op,它不会以任何方式影响模型的my_attr值。

ruby - 为什么扩展模块中的常量在用 self. 声明的类方法中不可用?

我认为在class中声明的方法之间没有区别block和用self.声明的block前缀,但有:moduleAVAR='some_constant'endclassBextendAclassOKB.m2#=>uninitializedconstantB::VAR为什么A的常量是可用m1但不在m2? 最佳答案 在Ruby中,常量查找与方法查找不同。对于方法查找,调用foo始终与调用self.foo相同(假设它不是私有(private)的)。调用常量FOO与self::FOO非常不同或singleton_class::FOO.使用非限定常

ruby - 在哈希参数上迭代调用 self.send 到 initialize()

我正在尝试理解以下Ruby代码。看起来attrs是一个散列,它作为参数传递,默认值为空散列。然后attrs.each迭代散列中的键值对(|k,v|)。在本次迭代中对键值对的元素调用self.send会达到什么效果?definitialize(attrs={},*args)super(*args)attrs.eachdo|k,v|self.send"#{k}=",vendend 最佳答案 send在第一个参数中调用该方法,并将其余参数作为参数传递。在这种情况下,我假设attrs中的内容是一个属性列表。假设它是这样的:{:name=>"

ruby - 在 Ruby 中,在类方法内部,self 是类还是实例?

我知道self是实例方法中的实例。那么,self是类方法内部的类吗?例如,以下内容是否适用于Rails?classPost 最佳答案 没错。类方法中的self是类本身。(也在类定义内部,例如defself.coolpost中的self。)您可以使用irb轻松测试这些花絮:classFoodefself.barputsself.inspectendendFoo.bar#=>Foo 关于ruby-在Ruby中,在类方法内部,self是类还是实例?,我们在StackOverflow上找到一个类

ruby - 'yield self' 和 instance_eval 一样吗?

如果用instance_eval:定义Foo有什么不同吗?..classFoodefinitialize(&block)instance_eval(&block)ifblock_given?endend。..或者使用“yieldself”:classFoodefinitializeyieldselfifblock_given?endend无论哪种情况,您都可以这样做:x=Foo.new{deffoo;'foo';end}x.foo所以“yieldself”意味着Foo.new之后的block总是在Foo类的上下文中求值。这是正确的吗? 最佳答案

ruby 我应该使用 self.或者 @

这是我的ruby代码classDemoattr_accessor:linesdefinitialize(lines)self.lines=linesendend在上面的代码中我可以使用@lines=lines大多数情况下,我看到人们在初始化方法中使用@。在这两者之间是否有首选的做法?为什么? 最佳答案 当您使用@lines时,您正在访问实例变量本身。self.lines实际上是通过类的lines方法;同样,self.lines=x通过lines=方法。所以当你想直接访问变量时使用@,当你想通过方法访问时使用self.。要直接回答您的

ruby-on-rails - (Ruby,Rails)模块和库中 SELF 的上下文......?

关于在模块或库中使用“SELF”的快速问题。基本上,“SELF”的范围/上下文是什么,因为它属于模块或库,如何正确使用它?有关我所说内容的示例,请查看随“restful_authentication”一起安装的“AuthenticatedSystem”模块。注意:我知道“self”在其他语言中等同于“this”,以及“self”如何在类/对象上运行,但是在模块/库的上下文中,“self”没有任何意义。那么在没有类的模块之类的东西中,self的上下文是什么? 最佳答案 在模块中:当您在实例方法中看到self时,它指的是包含该模块的类的

ruby - "self-documenting"代码如何才能不烦人?

关闭。这个问题是opinion-based.它目前不接受答案。想改善这个问题吗?更新问题,以便可以通过editingthispost用事实和引文回答问题.3年前关闭。Improvethisquestion我不确定这里的最佳实践是什么,但我经常看到缩写的变量名,尤其是当范围很小的时候。所以(使用简单的Ruby示例)而不是defadd_location(name,coordinates),我看到类似defadd_loc(name,coord)的东西——我什至可能会看到类似defadd_loc(n,x,y)的东西.我想当人们习惯于看到缩写时,更长的名字可能会让他们感到疲倦。冗长是否有助于可读

ruby - 何时在 Ruby 方法中使用 `self.foo` 而不是 `foo`

这不是Rails特有的——我只是以Rails为例。我在Rails中有一个模型:classItem(假设Item模型(类)有一个名为name的方法。)我什么时候需要使用self.name我什么时候可以只使用name(例如,#{name})? 最佳答案 在调用方法时更喜欢省略self.是惯用的;通常不需要。调用setter方法时,您必须使用self.foo=xxx,而不是foo=xxx,以便Ruby意识到您没有尝试创建新的局部变量。同样,如果您有一个与方法同名的现有局部变量do_something,这不太可能发生,您必须使用self.d

ruby - "extend self"与 "module_function"相同吗?

extendself和module_function是实现它的两种ruby​​方法,因此您可以在模块上调用方法,如果包含该模块也可以调用它。这些方式的最终结果有什么不同吗? 最佳答案 module_function将给定的实例方法设为私有(private),然后复制并将它们作为公共(public)方法放入模块的元类中。extendself将所有实例方法添加到模块的单例中,保持它们的可见性不变。moduleMextendselfdefa;endprivatedefb;endendmoduleNdefc;endprivatedefd;e