草庐IT

path2class

全部标签

ruby - "const_missing"定义中缺少常量和 "class << self"

在定义const_missing时,我对Ruby的行为感到非常困惑和class中的其他类方法定义而不是使用defself.foo句法。我正在尝试做这样的事情:classFooclass我主要使用class定义类方法的语法。但是,它没有按预期工作。const_missing永远不会被调用。以上结果导致NameError。像这样定义这两种方法按预期工作:defself.fooputsMISSINGenddefself.const_missing(name)puts"#{name}missing"end我认为classsyntax只是定义类方法的另一种方式,但完全等同于defself.foo

Ruby 2.4.1 Dir.children( dirname ) 为 Dir :Class"返回 "undefined method ` children'

我是Ruby的新手,正在尝试学习它。我使用的是最新的Ruby版本(2.4.1)和交互式RubyShell。我在Dir类中遇到过children方法。我试过这个例子fromthedocumentation:Dir.children("testdir")#=>["config.h","main.rb"]但它似乎不起作用,因为我收到以下消息:undefinedmethod`children'forDir:Class我错过了什么? 最佳答案 这似乎是某种文档困惑。Dir.children方法是在Feature#11302中引入的进入Ruby

ruby - LoadError 通过要求带有 :path or :git 的 gem

我遇到了一个非常奇怪的问题。我在github上fork了一个gem来做一些修改,在我的本地机器上克隆了我的repo,进行了更改并更改了另一个项目的Gemfile以从我的本地存储库中获取gem以进行测试。不幸的是,我在我的ruby​​脚本中需要该gem时遇到LoadError。rvmcurrent=>ruby-1.9.3-p448ruby--version=>ruby1.9.3p448(2013-06-27revision41675)[x86_64-linux]bundle--version=>Bundlerversion1.3.5我的Gemfile的内容:source'http://r

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 - 基本元编程 : extending an existing class using a module?

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

ruby - 如何在 Rails 4 中访问 *_path 和 *_url 助手

我正在阅读Rails:Checkoutputofpathhelperfromconsole并且没有一个解决方案对我有用,大概是因为它们都适用于Rails2/3。在Rails4/5中,如何从Rails控制台访问*_path和*_url助手? 最佳答案 运行Rails4,我得到它们:app.root_path=>"/"app.users_url=>"http://www.example.com/users" 关于ruby-如何在Rails4中访问*_path和*_url助手,我们在Stack

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 - Rails Brakeman 警告 : Dynamic Render Path false alarm?

我刚刚开始使用Rails,所以我使用Brakeman了解我的新手代码中的潜在漏洞。它在我的show.js.erb文件中抛出关于以下代码的高置信度“动态渲染路径”警告:$('#media-fragment').html('');我实际上预料到这是一个问题,所以不足为奇。所以我将其更改为以下内容:#controller:defshowiflegal_partial?@allowed_partial=params[:partial]elseraiseStandardError,"unexpectedpartialrequest:#{params[:partial]}"endendprivat

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.