草庐IT

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 - 使模块继承自 Ruby 中的另一个模块

我正在为Rails制作一个小程序,其中包含我在ApplicationHelper中的一个模块中构建的一些方法。模块。这是一个例子:moduleHelperdeftimeTime.now.yearendendmoduleApplicationHelper#InheritfromHelperhere...end我知道ApplicationHelper和includeHelper将在类的上下文中工作,但是您将使用什么进行模块到模块的继承?谢谢。 最佳答案 事实上,您可以在另一个模块中定义一个模块,然后将其包含在外部模块中。soross$c

ruby - 是否可以为 Ruby 中的模块创建别名?

在Python中,您可以使用'as'为模块设置别名:importmymoduleasmm但我似乎找不到ruby​​的等价物。我知道您可以include而不是require一个模块,但这有命名空间冲突的风险。有没有等同于Python模块别名的东西? 最佳答案 Ruby中的模块并没有那么特别,因此您可以将它们分配给另一个常量:[4](pry)main:0>moduleTestModule[4](pry)main:0*defself.foo[4](pry)main:0*"test"[4](pry)main:0*end[4](pry)mai

ruby-on-rails - 跨多个文件打破 ruby​​ 模块

我有一个ruby​​模块,它应该包含很多类moduleAclassFirst#somemethodsendclassSecond#somemethodsendclassThird#somemethodsendend我想在Rails中做的是将这些类分解成几个文件,将这个巨大的模块分解成几个相关文件的最佳做法可能是什么? 最佳答案 一种方法是提出这样的目录结构:(rootdir)├──a│  ├──first.rb│  ├──second.rb│  └──third.rb└──a.rb文件内容:#a.rbrequire_relative

ruby - 是否可以为子模块赋予与顶级类相同的名称?

背景:rubythinksI'mreferencingatop-levelconstantevenwhenIspecifythefullnamespaceHowdoIrefertoasubmodule's"fullpath"inruby?这是问题,提炼成一个最小的例子:#bar.rbclassBarend#foo/bar.rbmoduleFoo::Barend#foo.rbclassFooincludeFoo::Barend#runner.rbrequire'bar'require'foo'➔rubyrunner.rb./foo.rb:2:warning:toplevelconstan

ruby - 在 Ruby 中命名命名空间的首选方式(更好的风格)是什么?单数还是复数?

使用的优缺点是什么:FooLib::PluginsFooLib::Plugins::Bar对比FooLib::PluginFooLib::Plugin::Bar命名约定?你会用什么或者你在用什么?社区里比较常用的是什么? 最佳答案 使用:moduleFooLibendmoduleFooLib::PluginsendclassFooLib::Plugins::Plugin;end#thebaseforpluginsclassFooLib::Plugins::Bar或者换句话说:moduleFooLibmodulePluginsclas

ruby - 模块::NoMethodError

我有一个这样的模块:moduleProberdefprobe_invoke(type,data={})p=Probe.new({:probe_type=>type.to_s,:data=>data.to_json,:probe_status=>0,:retries=>0})p.saveendend我正在尝试从我的主程序中访问它,如下所示:require'prober'Prober.probe_invoke("send_sms",sms_text)但它会产生错误:undefinedmethod`probe_invoke'forProber:Module(NoMethodError)

ruby-on-rails - Ruby(和 Rails)嵌套模块语法

我想知道下面两个模块有什么区别#FirstExamplemoduleParentmoduleChildendend和#SecondExamplemoduleParent::Childend使用第二种方法,似乎必须预先定义父模块,否则会出现“未初始化常量”错误鉴于此,定义此类模块的首选方法是什么,然后根据语法和文件结构(即文件夹等)添加嵌套子项。非常感谢引用Rails方式。这两个示例的所有意图和目的是否相同? 最佳答案 在第一个示例中,它定义了Parent模块,然后是Child模块。正如您自己所说,第二个示例必须预先定义Parent模

ruby - 在另一个模块中扩展 Ruby 模块,包括模块方法

每当我尝试扩展ruby​​模块时,我都会丢失模块方法。include和extend都不会这样做。考虑片段:moduleAdefself.say_hiputs"hi"endendmoduleBincludeAendB.say_hi#undefined_method无论B包含还是扩展A,都不会定义say_hi。有什么办法可以完成这样的事情吗? 最佳答案 如果您是moduleA的作者并且经常需要它,您可以像这样重新编写A:moduleAmoduleClassMethodsdefsay_hiputs"hi"endendextendClass