我有以下模型,其中 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>£</span> <%= pt.input :instance_cost, :as => :string, wrapper: false, label: false %></td>
</tr>
<% end %>
end
我需要做两件事。
- 显示治疗的名称(如何用 simple_form 表达 User.user_treatments.treatment.name ?)
- 正确设置 instance_cost。它目前根本没有设置。