我有以下代码
@asset = Asset.first(
:include => [
:asset_statuses => [
:asset_status_name,
{:asset_location => [
{:asset_floor => :asset_building}
]}
],
:asset_type => [
:asset_category => :asset_department
]
],
(可能不是最好的数据库表设计,但这是我必须使用的)
Asset.first
正常运行并且正确地恢复了数据但是当我尝试在:include
方法中使用相同的to_json
时,它失败并出现以下错误:
@asset.to_json(
:include => [
:asset_statuses => [
:asset_status_name,
{:asset_location => [
{:asset_floor => :asset_building}
]}
],
:asset_type => [
:asset_category => :asset_department]
]
)
NoMethodError (undefined method `macro' for nil:NilClass):
to_json
方法与find具有相同的:include
语法;我不明白为什么它不起作用。
答案 0 :(得分:23)
如果其他人遇到了我所做的一个奇怪的相关问题......当您尝试包含未在模型上定义的关联时,to_json
也会返回此错误。
答案 1 :(得分:8)
我认为to_json
:include语法略有不同。
我经常做
@asset.to_json(:include => { :asset_statuses => {
:include => :asset_status_name}})
(从一个小的开始然后添加所有其他东西。烦人的架构!)
答案 2 :(得分:7)
尝试在单个to_json调用中混合第一和第二顺序关系时出现此错误。这是我最初的原因:
render :json => @reports.to_json(:include =>
[:report_type, :organisation, :analysis => {:include => :upload}]
抛出上面的“未定义的方法`宏'为nil:NilClass”异常。
以下是我修复它的方法:
render :json => @reports.to_json(:include =>
{:report_type => {}, :organisation => {},
:analysis => {:include => {:upload => {}}}})
Array适用于单阶关系,但对于二阶关系,包含对象需要是Hash。
答案 3 :(得分:2)
当我重写as_json函数时,我遇到了这个问题
def as_json(options={})
if options[:admin]
super(:methods => [:url_thumb] )
else
super(options.merge( :only => :id ))
end
end
由于某种原因,当您在没有参数的数组上调用as_json或to_json时,选项变为nil。
修复方法是:
def as_json(options={})
options = {} if options.nil?
if options[:admin]
super(:methods => [:url_thumb] )
else
super(options.merge( :only => :id ))
end
end