当前位置:  开发笔记 > 编程语言 > 正文

如何在Ruby on Rails中以编程方式找到命名空间/模块名称?

如何解决《如何在RubyonRails中以编程方式找到命名空间/模块名称?》经验,为你挑选了4个好方法。

如何在下面的过滤器中找到命名空间或模块"Foo"的名称?

class ApplicationController < ActionController::Base
  def get_module_name
    @module_name = ???
  end
end


class Foo::BarController < ApplicationController
  before_filter :get_module_name
end

Jason Harrel.. 98

这些解决方案都没有考虑具有多个父模块的常量.例如:

A::B::C

从Rails 3.2.x开始,您可以简单地:

"A::B::C".deconstantize #=> "A::B"

从Rails 3.1.x开始,您可以:

constant_name = "A::B::C"
constant_name.gsub( "::#{constant_name.demodulize}", '' )

这是因为#demodulize与#deconstantize相反:

"A::B::C".demodulize #=> "C"

如果您确实需要手动执行此操作,请尝试以下操作:

constant_name = "A::B::C"
constant_name.split( '::' )[0,constant_name.split( '::' ).length-1]


Hettomei.. 24

对于简单的情况,您可以使用:

self.class.parent


Daniel Lucra.. 22

这应该这样做:

  def get_module_name
    @module_name = self.class.to_s.split("::").first
  end

或者你也可以使用**self.class.name.demodulize**来达到这个目的. (11认同)

不,你不能,实际上demodulize确实返回没有命名空间的类名 (3认同)

正如Jason Harrelson指出的那样,这并未考虑多个父模块. (2认同)


Steropes.. 6

如果控制器确实有模块名称,这将有效,但如果没有,则返回控制器名称.

class ApplicationController < ActionController::Base
  def get_module_name
    @module_name = self.class.name.split("::").first
  end
end

但是,如果我们将此更改为:

class ApplicatioNController < ActionController::Base
  def get_module_name
    my_class_name = self.class.name
    if my_class_name.index("::").nil? then
      @module_name = nil
    else
      @module_name = my_class_name.split("::").first
    end
  end
end

您可以确定该类是否具有模块名称,并返回除您可以测试的类名以外的其他内容.



1> Jason Harrel..:

这些解决方案都没有考虑具有多个父模块的常量.例如:

A::B::C

从Rails 3.2.x开始,您可以简单地:

"A::B::C".deconstantize #=> "A::B"

从Rails 3.1.x开始,您可以:

constant_name = "A::B::C"
constant_name.gsub( "::#{constant_name.demodulize}", '' )

这是因为#demodulize与#deconstantize相反:

"A::B::C".demodulize #=> "C"

如果您确实需要手动执行此操作,请尝试以下操作:

constant_name = "A::B::C"
constant_name.split( '::' )[0,constant_name.split( '::' ).length-1]



2> Hettomei..:

对于简单的情况,您可以使用:

self.class.parent



3> Daniel Lucra..:

这应该这样做:

  def get_module_name
    @module_name = self.class.to_s.split("::").first
  end


或者你也可以使用**self.class.name.demodulize**来达到这个目的.
不,你不能,实际上demodulize确实返回没有命名空间的类名
正如Jason Harrelson指出的那样,这并未考虑多个父模块.

4> Steropes..:

如果控制器确实有模块名称,这将有效,但如果没有,则返回控制器名称.

class ApplicationController < ActionController::Base
  def get_module_name
    @module_name = self.class.name.split("::").first
  end
end

但是,如果我们将此更改为:

class ApplicatioNController < ActionController::Base
  def get_module_name
    my_class_name = self.class.name
    if my_class_name.index("::").nil? then
      @module_name = nil
    else
      @module_name = my_class_name.split("::").first
    end
  end
end

您可以确定该类是否具有模块名称,并返回除您可以测试的类名以外的其他内容.

推荐阅读
刘美娥94662
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有