草庐IT

clr-module-initializer

全部标签

Ruby 类 : initialize self vs. @variable

有人可以解释在定义类时初始化“self”和使用@variables之间的区别吗?举个例子classChild所以在这种情况下,我不能用@stuff替换self.stuff吗?有什么不同?此外,super()只是意味着Parent初始化方法中的任何内容,Child应该直接继承它,对吗? 最佳答案 一般来说,不是,self.stuff=stuff和@stuff=stuff是不一样的。前者在对象上调用stuff=方法,后者直接设置实例变量。前者调用一个可能是公共(public)的方法(除非在类中特别声明为私有(private)),而后者总

ruby - 导轨/RSpec : How to test #initialize method?

如何使用RSpec指定#initialize行为?例如这里:generator.rbclassGeneratorattr_accessor:seeddefinitialize(seed=nil)@seed=seed||pick_seedenddefpick_seedTime.now.to_iendendgenerator_spec.rbrequire'generator'describeGeneratorit"calls'pick_seed'methodunlessseedspecified"doendend我想设置从#initialize方法调用的pick_seed方法的期望值。

ruby - 在哈希参数上迭代调用 self.send 到 initialize()

我正在尝试理解以下Ruby代码。看起来attrs是一个散列,它作为参数传递,默认值为空散列。然后attrs.each迭代散列中的键值对(|k,v|)。在本次迭代中对键值对的元素调用self.send会达到什么效果?definitialize(attrs={},*args)super(*args)attrs.eachdo|k,v|self.send"#{k}=",vendend 最佳答案 send在第一个参数中调用该方法,并将其余参数作为参数传递。在这种情况下,我假设attrs中的内容是一个属性列表。假设它是这样的:{:name=>"

【笔记】internal/modules/cjs/loader.js:985 throw err; ^ Error: Cannot find module ‘node:util‘

[root@localhostusr]#cnpm-vinternal/modules/cjs/loader.js:985throwerr;^Error:Cannotfindmodule‘node:util’Requirestack:/usr/local/node/lib/node_modules/cnpm/bin/cnpmatFunction.Module._resolveFilename(internal/modules/cjs/loader.js:982:15)atFunction.Module._load(internal/modules/cjs/loader.js:864:27)atM

ruby-on-rails - railstutorial.org 中的 SessionsHelper : Should helpers be general-purpose modules for code not needed in views?

railstutorial.org有一个让我觉得有点奇怪的建议。Itsuggeststhiscode:classApplicationControllerincludeSessionsHelper使方法在ApplicationController中可用,是的,但它也使它们在任何View中都可用。我知道身份验证/授权是交叉的,但这真的是最好的地方吗?在我看来,这可能范围太广了。将实现有条件重定向(如railstutorial.org示例所做的)的before_filter的代码放在更通常包含View助手的模块中似乎令人惊讶。将View中不需要的功能放在ApplicationControl

ruby - Ruby 中的 "include module"和 "extend module"有什么区别?

这个问题在这里已经有了答案:关闭11年前。PossibleDuplicate:WhatisthedifferencebetweenincludeandextendinRuby?给定:modulemy_moduledeffoo...endend问题一有什么区别:classAincludemy_moduleend和classAextendmy_moduleend问题二将foo视为实例方法还是类方法?换句话说,这是否等同于:classAdeffoo...endend或:classAdefself.foo...endend?

ruby-on-rails - ruby /rails : How to determine if module is included?

在这里扩展我的问题(ruby/rails:extendingorincludingothermodules),使用我现有的解决方案,确定我的模块是否包含在内的最佳方法是什么?我现在所做的是在每个模块上定义实例方法,这样当它们被包含时,一个方法就可用,然后我只是向父模块添加一个捕获器(method_missing())所以如果它们不包括在内,我可以catch。我的解决方案代码如下:moduleFeaturesFEATURES=[Running,Walking]#includeFeatures::RunningFEATURES.eachdo|feature|includefeatureen

ruby-on-rails - rails "is not a module"错误

我在“lib”rails目录中构建了一个库。库的结构是这样的:lib/insurance/broker/fake_broker.rb该类类似于以下示例:moduleInsurancemoduleBrokerclassFakeBrokerdefinitialize(user_id,user_secret)@user_id=user_id@user_secret=user_secretendendendend因此,在我的result_controller中,我这样做:require'insurance/broker/fake_broker'defshowbroker=Insurance::

ruby-on-rails - ruby on rails find_or_initialize

在RubyonRails中有没有更好的方法来实现这一点?我正在搜索11个字段,所有字段也是必需的,如果找不到,请对其进行初始化。将有更多必填字段添加到其中。这个查询非常适合我,但它看起来并不是执行此操作的最佳方式。find_or_initialize_by_make_and_country_and_engine_and_power_and_body_and_doors_and_fuel_and_cylinders_and_transmission_and_gears_and_wheels(model,country,engine,power,body,doors,fuel,cylind

ruby-on-rails - Rails 3.0 & Ruby 1.9.2rc : Rake commands return 'already initialized constant' & stack level too deep errors. 任何想法

我正在尝试在Ubuntu10.04上运行Rails3beta4和Ruby1.9.2rc。它最初有效,但在完成我的第一个bundleinstall/package之后,我现在在所有Rails项目中都遇到以下错误。即使是基本的“railsnewtestproject”后跟一个rake也会显示错误消息。简而言之,我很难过。非常感谢任何有关可能导致此问题的帮助。我唯一注意到的事情——可能相关也可能不相关——是~/.bundle文件中的目录是ruby​​/1.9.1。我的机器上没有安装1.9.1-只有1.9.2rc。ruby-v带回1.9.2(in/home/john/Websites/sand