草庐IT

load_value

全部标签

ruby-on-rails - '需要': cannot load such file -- 'nokogiri\nokogiri' (LoadError) when running `rails server`

我正在使用DevKit在Windows8.1上运行全新安装的Ruby2.2.1。安装后我运行:geminstallrailsrailsnewtestappcdtestapprailsserver保留其他所有默认值。进程在最后一行失败,我没有运行服务器,而是收到错误消息in'require':cannotloadsuchfile--'nokogiri\nokogiri'(LoadError)每次都会发生这种情况,我环顾四周并尝试了我发现的所有方法来修复它,但到目前为止没有任何效果。这里的问题是什么?如何让一个简单的测试Rails应用程序正常工作? 最佳答案

ruby - 何时在 Ruby 中使用 `require` 、 `load` 或 `autoload` ?

我理解Ruby中require、load和autoload之间的细微差别,但我的问题是,你怎么知道要加载哪一个利用?除了能够在匿名模块中“包装”load之外,require似乎是首选。但是autoload允许您延迟加载文件——这听起来很棒,但我不确定您实际上比require获得了什么一种方法优于另一种方法吗?是否存在一种方法脱颖而出的情况? 最佳答案 通常,您应该使用require。load每次都会重新加载代码,因此如果您从多个模块执行此操作,将会做很多额外的工作。autoload的惰性在理论上听起来不错,但许多Ruby模块会做一些

ruby-on-rails - load 与 Ruby 中的 require 有何不同?

在RubyonRails应用程序中,load和require之间有什么主要区别吗?还是它们都具有相同的功能? 最佳答案 require在所有定义的搜索路径中搜索库并追加.rb或.so到您输入的文件名。它还确保图书馆只是包括一次。因此,如果您的应用程序需要库A和B,并且库B也需要库A,那么A将只加载一次。使用load,你需要添加库的全名,每次你加载它调用load-即使它已经在内存中。 关于ruby-on-rails-load与Ruby中的require有何不同?,我们在StackOverf

ruby - 将目录添加到 $LOAD_PATH (Ruby)

我见过两种常用的技术,用于将当前正在执行的文件的目录添加到$LOAD_PATH(或$:)。如果您不使用gem,我会看到这样做的好处。显然,一个似乎比另一个更冗长,但有理由优先考虑另一个吗?第一个,冗长的方法(可能有点矫枉过正):$LOAD_PATH.unshift(File.expand_path(File.dirname(__FILE__)))unless$LOAD_PATH.include?(File.expand_path(File.dirname(__FILE__)))还有更直接、快捷的方法:$:.unshiftFile.dirname(__FILE__)有什么理由比另一个更好

ruby-on-rails - rails 4 : assets not loading in production

我正在尝试将我的应用程序投入生产,但图像和CSSAssets路径无法正常工作。这是我目前正在做的事情:图片资源位于/app/assets/images/image.jpg样式表位于/app/assets/stylesheets/style.css在我的布局中,我引用了这样的css文件:true%>在重新启动unicorn之前,我运行RAILS_ENV=productionbundleexecrakeassets:precompile它成功了,我在public/assets中看到了指纹文件目录。当我浏览我的网站时,我收到mysite.com/stylesheets/styles.css的

ruby - `:key => "值"` and `键: "value"` hash notations?有区别吗

:key=>"value"(hashrocket)和key:"value"(Ruby1.9)符号之间有什么区别吗?如果没有,那么我想使用key:"value"表示法。是否有gem可以帮助我将:x=>符号转换为x:符号? 最佳答案 是的,有区别。这些是合法的:h={:$in=>array}h={:'a.b'=>'c'}h[:s]=42但这些不是:h={$in:array}h={'a.b':'c'}#butthisisokayinRuby2.2+h[s:]=42您还可以使用任何东西作为=>的键,这样您就可以这样做:h={C.new=>1

ruby - 为什么 Ruby 1.9.2 从 LOAD_PATH 中删除 ".",还有什么替代方案?

Ruby1.9.2的最新变更集不再生成当前目录.你的一部分LOAD_PATH.我有很多Rakefile假设.是LOAD_PATH的一部分,所以这打破了他们(他们报告所有基于项目路径的require语句“没有这样的文件要加载”)。这样做有什么特别的理由吗?至于修复,添加$:无处不在,但似乎非常骇人听闻,我不想那样做。使我的Rakefiles1.9.2+兼容的首选方法是什么? 最佳答案 它被认为是“安全”风险。你可以使用绝对路径绕过它File.expand_path(__FILE__)etal或做require'./filename'(

ruby 'require' 错误 : cannot load such file

我有一个文件,main.rb,内容如下:require"tokenizer.rb"tokenizer.rb文件位于同一目录,其内容为:classTokenizerdefself.tokenize(string)returnstring.split("")endend如果我尝试运行main.rb,我会收到以下错误:C:\DocumentsandSettings\my\src\folder>rubymain.rbC:/Ruby193/lib/ruby/1.9.1/rubygems/custom_require.rb:36:in`require':cannotloadsuchfile--to

ruby - 如何避免 "cannot load such file -- utils/popen"来自 OSX 上的 Homebrew 软件

当我在终端中运行brew时出现错误:/System/Library/Frameworks/Ruby.framework/Versions/2.0/usr/lib/ruby/2.0.0/rubygems/core_ext/kernel_require.rb:55:in`require':cannotloadsuchfile--utils/popen(LoadError)from/System/Library/Frameworks/Ruby.framework/Versions/2.0/usr/lib/ruby/2.0.0/rubygems/core_ext/kernel_require.

ruby-on-rails - rake db :migrate db:reset and db:schema:load之间的区别

rakedb:migrate和rakedb:reset之间的区别对我来说非常清楚。我不明白的是rakedb:schema:load与前两者有何不同。只是为了确保我在同一页面上:rakedb:migrate-运行尚未运行的迁移。rakedb:reset-清除数据库(大概是做一个rakedb:drop+rakedb:create+rakedb:migrate)并在新数据库上运行迁移。 最佳答案 db:migrate运行尚未运行的(单个)迁移。db:create创建数据库db:drop删除数据库db:schema:load在schema.