有没有一种方法可以为多个角色声明attr_accessible而无需大量重复?如果我有多个用户角色,并且允许每个角色编辑不同的属性子集,那么我的attr_accessible声明如下所示:attr_accessible:first_name,:last_name,:active,:as=>:adminattr_accessible:first_name,:last_name,:as=>:managerattr_accessible:first_name,:last_name,:as=>:guest我也愿意A)定义一组可以共享的可访问属性不同的角色或B)定义一组可以访问相同角色的角色属性
我正在使用class_eval编写要在当前类的上下文中执行的代码。在下面的代码中,我想为属性值的变化添加一个计数器。classClassdefattr_count(attr_name)attr_name=attr_name.to_sattr_readerattr_name#createtheattribute'sgetterclass_eval%Q{@count=0def#{attr_name}=(attr_name)@attr_name=attr_name@count+=1enddef#{attr_name}@attr_nameend}endendclassFooattr_count
如果在模型文件中我只有这段代码:classUsers这是什么意思?与模型相关的所有属性是否可访问?如何设置“attr_accessible”以便不允许访问该模型的任何字段? 最佳答案 只需设置:classUsers正如PanThomakos所说(attr_accessible是可以被mass-ret的参数数组。所以如果你不发送任何符号,那么就没有参数可以访问。Thisticketwasuseful 关于ruby-on-rails-我如何设置'attr_accessible'以不允许访问使
我希望下面的代码能按预期工作,但它给了我一个NoMethodError(为#classMyClassendmy_object=MyClass.newmy_object.instance_variable_set(:@foo,"bar")MyClass.send("attr_reader",:foo)putsmy_object.foo问题是我在一个更大的应用程序中使用完全相同的代码并且它完全按照我的预期工作,但是当我将它简化为这个最基本的示例时它失败了。(我知道还有很多其他方法可以完成我在Ruby中所做的事情) 最佳答案 使用Modu
我有一个使用简单形式的普通形式。现在我想添加一个在模型中没有任何对应字段的输入,它将由Controller处理。我试过了但这给出了一个Methodnotfound:attr_not_in_obj错误。我显然可以使用标准的Rails帮助程序,但是我会错过输入周围的所有简单格式HTML,并且复制似乎不太正确。简而言之:我正在寻找类似rails标签助手的简单版本,与模型没有任何联系。如何添加与模型属性不对应的输入? 最佳答案 为什么不添加:attr_accessor:attr您模型的类定义?这样你的代码:应该可以。或如果此解决方案不合适,
只是想知道是否有人可以从强类型的角度阐明RubyonRails中gettersetter的基础知识。我对rubyonrails还很陌生,主要对.NET有很好的理解。例如,假设我们有一个名为Person的.net类classPerson{publicstringFirstname{get;set;}publicstringLastname{get;set;}publicAddressHomeAddress{get;set;}}classAddress{publicstringAddressLine1{get;set;}publicstringCity{get;set;}publics
我在Rails模型中使用attr_accessor_with_default的一些代码现在给我一个弃用警告,告诉我“改用Ruby!”所以,考虑到ruby1.9.2中可能有一个新的位使attr_accessor处理默认值,我用谷歌搜索了它,但我没有看到。我确实看到了一堆方法来覆盖attr_accessor来处理默认值。当他们告诉我“使用Ruby”时,这就是他们的意思吗?或者我现在应该写完整的getters/setters吗?或者有什么我找不到的新方法吗? 最佳答案 Thisapidockpage建议只在初始化方法中执行。classSo
假设我有一个类AclassAattr_accessor:x,:ydefinitialize(x,y)@x,@y=x,yendend如何在不知道它们的命名方式的情况下获取x和y属性。例如a=A.new(5,10)a.attributes#=>[5,10] 最佳答案 使用内省(introspection),卢克!classAattr_accessor:x,:ydefinitialize(*args)@x,@y=argsenddefattrsinstance_variables.map{|ivar|instance_variable_ge
在Ruby中,实例变量有四种不同的getter和setter方法,attr、attr_reader、attr_writer和attr_accessor。问题是,在Rubyattr:dilithium中,与attr_reader:dilithium相同,如果附加参数为true,则与attr_accessor:dilithium相同通过了吗?也就是说是classEnterpriseattr:dilithium,true等同于classEnterpriseattr_accessor:dilithiumattr和attr_accessor这两个函数是否或多或少是多余的?
我看到这样的代码:classPersondefinitialize(name)@name=nameendend我知道这让我可以做person=Person.new之类的事情,并像其他方法一样在我的类中的其他地方使用@name。然后,我看到了如下代码:classPersonattr_accessor:nameend...person=Person.newperson.name="David"我只是对这两种方法网格不知所措。definitialize(name)的特殊用途是什么?我想attr_accessor允许我读写。这意味着它们是两种不同的方法。是的?想要澄清definitialize