草庐IT

new-style-class

全部标签

ruby - 可配置的 ruby​​ 记录器设置 : Logger. new().level = variable

我想更改应用程序(ruby)的日志记录级别。require'logger'config={:level=>'Logger::WARN'}log=Logger.newSTDOUTlog.level=Kernel.const_getconfig[:level]好吧,irb对此并不满意,并向我抛出“NameError:错误的常量名称Logger::WARN”。啊!我被侮辱了。我可以在某些情况下/何时解决这个问题,或者做log.level=1,但必须有更优雅的方法!有没有人有什么想法?-丹尼尔 最佳答案 为什么不直接在config哈希中使用

ruby-on-rails - Capistrano:不知道如何构建任务 'deploy:new_release_path'

我是第一次部署到DigitalOceanUbuntudroplet。我已经配置了所有内容并执行了所有步骤,现在我正在执行命令:capproductiondeploy:initial。对于此命令,我收到此错误消息:capaborted!Don'tknowhowtobuildtask'deploy:new_release_path'(see--tasks)/Users/Christopher/.rbenv/versions/2.3.1/lib/ruby/gems/2.3.0/gems/rake-12.0.0/lib/rake/task_manager.rb:58:in`[]'/Users/

Ruby:阻止 HTTP.new.start 和动态 HTTP(S)

我需要一个应用程序来阻止HTTP请求,所以我不得不添加几行代码,唯一我想不通的是语句ifuri.scheme=='https';http.use_ssl=true有没有办法在当前语句中设置http/https:Net::HTTP.new(uri.host,uri.port).startdo|http|#CausesandIOError...ifuri.scheme=='https'http.use_ssl=trueendrequest=Net::HTTP::Get.new(uri.request_uri)http.request(request)end添加:IOError:use_ss

ruby - 基本元编程 : extending an existing class using a module?

我希望我的模块的一部分能够扩展String类。这行不通moduleMyModuleclassStringdefexclaimselfNoMethodError但这样做moduleMyModuledefexclaimself"thisisastring!!!!!"我不希望MyModule的所有其他功能都被String束缚。在最高级别再次包含它似乎很丑陋。当然有更简洁的方法来做到这一点? 最佳答案 exclaim第一个示例中的方法是在一个名为MyModule::String的类中定义的,与标准无关String类(class)。在您的模块

ruby - 为什么 File.new 的参数不是符号而是字符串?

我想知道为什么编写File库的人决定用字符串而不是符号来确定文件打开模式的参数。比如现在是这样的:f=File.new('file','rw')但这不是更好的设计吗f=File.new('file',:rw)甚至f=File.new(:file,:rw)例如?这似乎是使用它们的最佳场所,因为参数绝对不需要可变。我很想知道为什么会这样。更新:我刚读完arelatedquestionaboutsymbolsvs.strings,我认为大家的共识是,符号只是不如字符串广为人知,反正大家都习惯用字符串来索引哈希表。但是,我认为Ruby标准库的设计者以对符号主题一无所知为由辩护是不合理的,所以我

ruby - 为什么 self.class === MyClass 返回 false,而 self.class == MyClass 返回 true?

我正在使用Ruby的case语法来设置一些基于self.class的简单逻辑,如下所示:caseself.classwhenFirstClassdostuff....whenSecondClassdootherstuff...end我很快意识到这总是返回nil。经过仔细调查,我发现case使用===而不是==检查是否相等。在我的终端中运行self.class==FirstClass时,我按预期得到true,但是self.class===FirstClass返回假的。查看ruby​​文档,我找到了followingexplanation===:CaseEquality–ForclassO

ruby-on-rails - Ruby on Rails : allow the user to enter a new information, 或单击下拉菜单选择现有信息

这里是新的ROR程序员。我正在尝试构建一个Web应用程序,该应用程序允许用户填写表单,他们在其中输入公司信息,然后通过单击提交,将输入添加到数据库中。目前,如果用户要创建一个新条目,他们会看到几个字段,例如“公司名称”。有一个空白框供他们输入新公司,旁边有一个下拉菜单,用户可以使用该菜单查看数据库中的现有公司。"SelectaCompany")%>我正在寻找一种允许用户输入新公司的方法,或者单击下拉菜单并选择现有公司。目前:如果未在文本框中输入任何内容且未从下拉列表中选择任何选项,则将其保存为空白。如果输入了一些内容,但没有选择任何选项,它将被保存为空白。但是,如果输入内容并从下拉列表

ruby - 如何为使用 class_eval 定义的方法添加 RDoc 文档?

我正在使用class_eval来更简洁地定义一堆重复的方法,像这样:%w{greasychunkybacon}.product(%w{flyingskypoodle}).eachdo|a,b|class_eval"def#{a}_#{b};do_something;end"end我希望所有生成的方法都包含在RDoc文档中。是否有RDoc指令“手动”将方法添加到类的方法列表中?我找不到。 最佳答案 请参阅RDocdocumentationforRDoc::Parser::Ruby中有关元编程方法和隐藏方法和属性的部分.在你的情况下,你

ruby - base.extend 与 base.class_eval 扩展

这个语法在功能上是否等同defself.included(base)base.class_evaldoextendClassMethodsendend为了这个?defself.included(base)base.extendClassMethodsend 最佳答案 唯一相关的区别是只有类响应“class_eval”,而类和实例都响应“扩展”。如果您不打算将您的方法与对象实例一起使用,那么它们是等效的,尽管第二个实现可用于将实例方法添加到特定实例,而第一个不能。 关于ruby-base.

ruby - class ClassName <::Other ClassName 在 Ruby 中做什么?

昨天在RSpec中找到了如下代码:classOptionParser这是做什么的?这和classOptionParser有什么区别?? 最佳答案 一个可运行的例子可能最好地解释了这个想法:classCdefinitializeputs"Attoplevel"endendmoduleMclassCdefinitializeputs"InmoduleM"endendclassP运行时产生:InmoduleMAttoplevel 关于ruby-classClassName htt