在呈现为JSON时,如何将具有不同foreign_key显示的自定义belongs_to关联作为关联名称?

时间:2013-01-09 23:15:58

标签: ruby-on-rails ruby-on-rails-3 json rails-activerecord

我对rails非常陌生,并且在我的Champion模型上通过belongs_to创建了5个关联,这些关联连接到Ability模型,该模型将has_one关联返回到Champion模型。

这5个关联使用与关联名称加“_id”匹配的外键。当我去渲染页面时,我看到“_id”值显示为整数,但希望这些值显示为实际记录。因此,它不会只显示一个整数,而是显示包含所有字段的完整Ability记录。

这是我的Champion.rb模型:

class Champion < ActiveRecord::Base
  attr_accessible :q_id,
                  :w_id,
                  :e_id,
                  :r_id,
                  :passive_id

  belongs_to :q, :class_name => "Ability", :foreign_key => "q_id"
  belongs_to :w, :class_name => "Ability", :foreign_key => "w_id"
  belongs_to :e, :class_name => "Ability", :foreign_key => "e_id"
  belongs_to :r, :class_name => "Ability", :foreign_key => "r_id"
  belongs_to :passive, :class_name => "Ability", :foreign_key => "passive_id"
end

和ability.rb模型:

class Ability < ActiveRecord::Base
  has_one :champion
end

显示模型的控制器:

class ApplicationController < ActionController::Base
  protect_from_forgery

  def show_all
    load_models

    respond_to do |format|
      format.json { render :json => { "champions" => @champions } }
    end
  end

  protected
  def load_models
    @champions = Champion.all
  end
end

那么如何设置它以使JSON显示“q”,“w”,“e”,“r”和“被动”而没有“_id”,并显示整个能力记录?现在它只显示包含id的实际数据库字段,但不显示我想要的记录。任何帮助表示赞赏!

1 个答案:

答案 0 :(得分:0)

最简单的方法是:

respond_to do |format|
  format.json { render :json => @champions.to_json(:include => {:q => {}, :w => {}}) }
end

我可能会建议查看类似RABL的内容。它将使处理这些更复杂的json响应更清晰。它上面有一个很好的Railscast here