1

我有以下模型,其中 UserTreatment 本质上是一个查找表,但它有另一个名为 instance_cost 的字段,它针对每个关系存储一个整数。

class User < ActiveRecord::Base
    has_many :user_treatments
    has_many :users, :through => :user_treatments
end

class UserTreatment < ActiveRecord::Base
    attr_accessible :instance_cost

    belongs_to :user
    belongs_to :treatment
end

class Treatment < ActiveRecord::Base
    attr_accessible :name

    has_many :user_treatments
    has_many :users, :through => :user_treatments
end

所以我可以做这样的事情来获得用户 id 14 的第一个实例成本

1.9.3p429 :181 > User.find(14).user_treatments.first.instance_cost
=> 100

这得到了治疗的名称

1.9.3p429 :181 > User.find(14).user_treatments.first.treatment.name
=> "Sports Massage"

但是,我在使用 simple_form_for 以表格形式表示它们时遇到问题

<% simple_form_for @user do |f| %>

   # This sucessfully gives us the checkboxes of all treatments and stores them in the UserTreatments table
<%= f.collection_check_boxes(:treatment_ids, Treatment.all, :id, :name) %>

 <%= f.fields_for :user_treatments do |pt| %>
        <tr>
            <td>
                <!-- I WANT THE NAME OF THE TREATMENT HERE --> 
            </td>
            <td><span>&pound;</span> <%= pt.input :instance_cost, :as => :string, wrapper: false, label: false  %></td>
        </tr>
    <% end %>
end

我需要做两件事。

  1. 显示治疗的名称(如何用 simple_form 表达 User.user_treatments.treatment.name ?)
  2. 正确设置 instance_cost。它目前根本没有设置。
4

1 回答 1

2

当您为嵌套关联执行 fields_for 时,您需要在 User 模型中添加以下内容:

accepts_nested_attributes_for :user_treatments

否则,它不会保存信息。

要访问处理的名称,您可以通过表单创建者对象的对象方法,如下所示:

<%= f.fields_for :user_treatments do |pt| %>
  <tr>
    <td><%= pt.object.treatment.name %></td>
    ...
  </tr>
<% end %>
于 2013-06-03T06:57:28.173 回答