草庐IT

Python中的null是什么?

全部标签

ruby-on-rails - Rails 中的递归路由

是否可以在Rails中创建递归路由?我有一个应用程序,允许管理员创建页面。页面模型是一个嵌套集,因此每个页面都有一个parent_id因此页面以树的形式构建。页面模型还使用FriendlyID插件为每个页面提供slug。当用户浏览网站时,我希望他们看到url中的嵌套结构-这对于搜索引擎以及可能希望通过截断url浏览网站的任何用户来说更好。我想要的是:http://example.com/page/page/page/page...等等现在显然我可以创建一个嵌套map,比如10个嵌套,并希望没有站点超过该限制,但我很好奇是否有其他方法... 最佳答案

ruby-on-rails - ActiveRecord::Errors 的 Rails 3 替代品是什么?

ActiveRecord::Errors的Rails3替代品是什么?在Rails2.3.8中,这是一个对象:>>ActiveRecord::Errors=>ActiveRecord::Errors在Rails3.0.0rc中,你会得到一个NameError:>>ActiveRecord::ErrorsNameError:uninitializedconstantActiveRecord::Errorsfrom(irb):2我正在尝试制作wizardly生成器与Rails3一起工作。$railsgwizardly_scaffoldhome但失败了:/Library/Ruby/Gems/1

ruby - 在 ruby​​ 上,为什么 include 是私有(private)的而 extend 是公共(public)的?

在ruby上,为什么include是private,而Object#extend是public? 最佳答案 Object#extend必须是公开的,否则您将无法使用它。毕竟,它的目的是将模块混合到对象中,因此您通常会像obj.extend(Foo)那样调用它,这对于私有(private)方法是不可能的。Module#include通常只在模块体内使用,如下所示:classBarincludeFooend即它通常在没有接收者的情况下被调用,所以它不必公开。当然,它也必须是私有(private)的。我猜它之所以是私有(private)的

ruby - 如何对命名空间中的模型执行 has_many

Rails3为我们提供了这些很棒的生成器,可以将模型和Controller放入命名空间,哇!但现在我无法将它们与其他模型相关联。我正在尝试通过与命名空间模型关联来实现has_many。我已经在互联网上搜索了几天,但没有找到任何示例。/app/models/templates/practice.rbclassTemplates::Practice"position",:dependent=>:destroy,:class=>'Templates::PracticeSequence'has_many:seasons,:through=>:practice_sequences,:order=

ruby-on-rails - 你能覆盖 Ruby 中的别名方法吗?

在Ruby中,当方法被别名时,别名指向原始方法的主体。所以即使你重新定义了原来的方法,别名也会继续使用原来的定义。classFoodefbar"bar"endalias:saloon:barendclassFoodefbar"BAR"endendputsFoo.new.saloon将返回'bar'而不是'BAR'。有没有办法让沙龙使用酒吧的新定义?编辑:我应该更清楚。该示例只是问题的说明-这不是我需要解决的实际问题。当您在rails的核心中链接别名时,问题会更加复杂。例如。perform_action以基准测试模块为别名,然后也以flash模块为别名。所以现在对perform_acti

ruby - 模式匹配时 =~ 和 match() 有什么区别?

我正在使用Ruby1.9.3。我在玩一些模式,发现了一些有趣的东西:示例1:irb(main):001:0>/hay/=~'haystack'=>0irb(main):003:0>/st/=~'haystack'=>3示例2:irb(main):002:0>/hay/.match('haystack')=>#irb(main):004:0>/st/.match('haystack')=>#=~返回其第一个匹配项的第一个位置,而match返回模式。除此之外,=~和match()还有什么区别吗?执行时间差(根据@Casper)irb(main):005:0>quickbm(10000000

ruby - 当我不提供方法名称时,为什么 Ruby 会调用 `call` 方法?

给定以下模块:moduleFoodefself.call'foo'endend我当然希望以下内容有效:putsFoo.call#outputs"foo"但是,我没想到这会起作用:putsFoo.()#outputs"foo"显然,当方法名称被省略时,Ruby假定我想调用call方法。这在哪里记录,为什么它会这样? 最佳答案 Proc#call:Invokestheblock,settingtheblock’sparameterstothevaluesinparamsusingsomethingclosetomethodcalling

ruby - 为什么在初始化时不使用 setter 方法?

最近我一直在阅读“Ruby中的实用面向对象设计”,我注意到最佳实践之一是使用访问器方法而不是直接获取@instance_variable。例如:classFooattr_accessor:bardefinitialize(my_argument)@bar=my_argumentend#bad#deflorem_ipsum#@bar*999#end#gooddeflorem_ipsumbar*999endend让事情保持干燥是有意义的,并且,以防万一我需要在实际获取它的值之前以某种方式处理@bar。但是,我注意到initialize方法直接设置了@bar实例变量的值:classFooat

ruby - 污染 Ruby 对象的目的是什么?

我知道将不受信任的对象标记为受污染的可能性,但根本目的是什么,我为什么要这样做? 最佳答案 将污点作为一种安全预防措施进行跟踪,以确保不受信任的数据不会被错误地用于计算、交易或解释为代码。通过内置语言功能跟踪污点比通过编码约定或依赖代码审查跟踪更清晰、更可靠。例如,来自用户的输入通常可以被认为是“不可信的”,直到它被适本地清理以插入到数据库中。通过将输入标记为受污染,Ruby可确保进行令人满意的清理并防止潜在的SQL注入(inject)攻击。有关演示如何在没有此类Perl和Ruby模块的情况下跟踪污点的“古老”(2005年)编码实践

ruby-on-rails - 解析 URL 以提取域的最佳方法是什么?

这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:RubycodetoextracthostfromURLstring我发现这个模块叫做URI可以解析url。(我是ruby​​的新手。在这种情况下,“模块”是否与“库”同义?)然后您可以提取主机名。uri=URI.parse("http://www.ruby-lang.org/")...puri.host#=>"www.ruby-lang.org"据此,我想您可以删除“www.”并使用正则表达式保留其他子域。有没有人有更直接的替代方法或者这种方法是否正确?