草庐IT

ruby - Rails—— self 与@

我正在学习MichaelHartl的RoR教程,它涵盖了密码加密的基础知识。这是当前的用户模型:classUsertrue,:length=>{:maximum=>50}validates:email,:presence=>true,:format=>{:with=>email_regex},:uniqueness=>{:case_sensitive=>false}validates:password,:presence=>true,:length=>{:maximum=>20,:minimum=>6},:confirmation=>truebefore_save:encrypt_pa

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 - 为什么 Array#each 返回具有相同元素的数组?

我正在学习each如何在ruby​​中工作的细节,我尝试了以下代码行:p[1,2,3,4,5].each{|element|el}结果是一个数组[1,2,3,4,5]但我不认为我完全理解为什么。为什么each的返回值是同一个数组?每个人不只是提供一种迭代方法吗?或者只是each方法返回原始值的常见做法? 最佳答案 Array#each返回调用它的[array]对象:block的结果是discarded。因此,如果原始数组没有icky副作用,那么什么都不会改变。也许你的意思是使用map?p[1,2,3,4,5].map{|i|i*i}

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-on-rails - 计算最近 7 天内创建的记录

如何更改下面的查询以仅选择过去7天内创建的记录?self.favorites.count此函数位于我的User模型中。defcalculate_user_scoreunlessself.new_record?self.score=(self.links.count*5)+(self.favorites.count*0.5)endend 最佳答案 您可以像这样添加一个where条件:self.favorites.where('created_at>=?',1.week.ago).count对于您的calculate_user_scor

ruby - 如何格式化 ruby​​ 中的日期以包含 "rd",如 "3rd"

我想格式化一个日期对象,以便我可以显示诸如“7月3日”或“10月1日”之类的字符串。我在Date.strftime中找不到生成“rd”和“st”的选项。有人知道怎么做吗? 最佳答案 除非你使用的是Rails,否则请添加此ordinalize方法(不要脸的代码从Rails源代码中提取)到Fixnum类classFixnumdefordinalizeif(11..13).include?(self%100)"#{self}th"elsecaseself%10when1;"#{self}st"when2;"#{self}nd"when3;

ruby 我应该使用 self.或者 @

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