假设您正在用不同的元数覆盖子类中的方法:classAdeffoo(arg)#arityis1#doingsomethinghereendendclassB有没有办法在线获取super的元数?(实际用例:我调用super时知道父类(superclass)不接受任何参数。但是,如果父类(superclass)实现(在gem中)发生变化,我想发出警告。)感谢您的帮助! 最佳答案 关于您的实际用例:无需亲自检查参数。打电话super(arg1)如果参数计数不匹配,Ruby将引发ArgumentError。更新由于一些反对票,我想我应该回答你
如何为super调用设置一个block为nil?classAdeffooifblock_given?result=yield#dostuffwiththeyieldresultend#somemorecodeendendclassBblockcalled#=>blockcalled我不想让block两次。block_given?在类A中是否有可能返回false?背景是我不拥有A类,我无法更改它的foo方法,但我想避免调用我的block两次。我也不想将虚拟/空block传递给super,因为A的foo方法的行为在给定block时发生变化。 最佳答案
在ruby中,super是keyword而不是一种方法。为什么要这样设计?Ruby的设计倾向于实现尽可能多的方法;关键字通常保留给有自己语法规则的语言特性。然而,super看起来和行为都像一个方法调用。(我知道在纯Ruby中实现super会很麻烦,因为它必须从caller或useatrace_func中解析方法名称。这单独并不能阻止它成为一个方法,因为很多Kernel的方法不是在纯Ruby中实现的。) 最佳答案 它的行为有点不同,因为如果你不传递参数,所有当前参数(和block,如果存在的话)都会被传递......我不确定这将如何作
我们有RoR应用程序,我们计划在新版本中制作js接口(interface)(extjs或闭包)。是否可以将GWT与RoR一起使用? 最佳答案 是的,将GWT与RoR结合使用是完全可能的。客户端服务器通信将通过JSON,RoR可以轻松生成。当您使用HTML/JavaScript/CSS创建客户端应用程序时,GWT最有效,如果您想要逐步增强现有的HTMLUI,jQuery等可能是更好的选择。 关于ruby-on-rails-GWT和RubyonRails,我们在StackOverflow上找
我今晚在部署时遇到了一些问题,我正在努力尽快解决这个问题我不知道为什么会这样。在本地一切正常,但在heroku上却不行。我在研究后尝试了各种不同的修复方法,但我可能不得不求助于完全重命名此类CommentsController(希望能奏效)。最好的方法是什么?我是Rails的新手,所以我需要一些帮助来正确地进行这些更改。这是CommentsController的样子,仅供引用:classCommentsController评论与每个帖子相关联(用户可以对帖子发表评论)。如果需要,我也会发布其他代码。这是来自heroku日志的错误2013-04-09T05:55:19.454545+00
classAdefinitializeprint"Hello!"endendclassB我明白了wrongnumberofarguments(1for0)但是为什么?类B需要一个参数,我给它没问题。类A不需要任何参数,所以我根本没有通过super传递任何东西。 最佳答案 您需要使用super()才能不带参数调用它。Super本身会使用提供给自身的参数(即“名称”)自动调用父级 关于ruby-调用super时参数数量错误,我们在StackOverflow上找到一个类似的问题:
从之前的帖子中我得到了在emacs中工作的Ruby模式。这很好用。Settingup.emacsfileformacrubydevelopment虽然我们公司使用4个空格而不是默认的2个缩进。我很难让它工作。这是我的.emacs文件(add-to-list'load-path"~/rdoc-mode.el")(require'ruby-mode)(setqindent-tabs-modenil);alwaysreplacetabswithspaces(setq-defaulttab-width4);settabwidthto4forallbuffers有没有人看到我做错了什么?谢谢!
最近我发现defined?运算符有一些奇怪的行为,用于检查super关键字是否可以在当前上下文中使用。通常它工作正常,但是当我尝试组合定义的时?super用一点元编程检查,它给了我意想不到的结果。显示比描述更容易,所以这里是一个提炼的例子来说明问题:classA;defself.def_f!;singleton_class.send(:define_method,:f){defined?super}endendclassAA(A和AA类都有.def_f!类方法)A.def_f!A.f#=>nilAA.f#=>nil(A.f没有super和AA.f调度到A.f,所以到目前为止一切正常,但
根据documentationformodulesandclasses,调用super(不带参数或括号)使用相同的参数调用父方法:Whenusedwithoutanyargumentssuperusestheargumentsgiventothesubclassmethod.为“参数变量”分配一个新值似乎会改变这种行为:classMyClassdeffoo(arg)puts"MyClass#foo(#{arg.inspect})"endendclassMySubclass输出:MySubclass#foo("initalvalue")MyClass#foo("initalvalue")
好吧,我想我得到了什么superdoes独立的。基本上在设计中,如果Users::RegistrationsController,然后在任何行动中,都有一个super将首先调用父级中相同命名操作的逻辑Devise::RegistrationsController,然后调用你写的内容。换句话说...classDevise::RegistrationsControllerdefnewputs"thisisintheparentcontroller"endendclassUsers::RegistrationsController"thisisintheparentcontroller"#=