0

在 fields_for 块内,我如何引用关系字段的值。

例如:

应用程序/模型/cart.rb

class Cart < ActiveRecord::Base
  attr_accessible :lineitems_attributes
  has_many :lineitems, dependent: :destroy
  accepts_nested_attributes_for :lineitems

  def total_price
    lineitems.to_a.sum { |item| item.total_price }
  end
end

应用程序/模型/lineitem.rb

class Lineitem < ActiveRecord::Base
  attr_accessible :cart_id, :quantity, :package_id, :part_id
  belongs_to :cart
  belongs_to :package
  belongs_to :part

  def total_price
    if package_id?
      return package.price * quantity
    end

    if part_id?
      return part.price * quantity
    end
  end
end

应用程序/模型/package.rb

class Package < ActiveRecord::Base
  attr_accessible :description, :img_src, :name, :price
  has_many :lineitems
end

app/views/cart/_form.html.erb

<%= form_for @cart do |f| %>
  <%= c.fields_for :lineitems do |i| %>
    <%= render 'lineitem_fields', :f => i %>
  <% end %>
  <%= c.submit %>
<% end %>

app/views/cart/_lineitem_fields.html.erb

<%= f.text_field :quantity %>

<% if :package_id? %>
  <%= f.text_field :package_id %>
<% else %>
  <%= f.text_field :part_id %>
<% end %>

<%= link_to 'Remove',
         lineitem_path(:id),
         :method => :delete,
         :confirm => t('.confirm', :default => t("helpers.links.confirm",
         :default => 'Are you sure?')) %>    

图式的相关片段

create_table "carts", :force => true do |t|
  t.integer "branch_id"
  t.datetime "created_at", :null => false
  t.datetime "updated_at", :null => false
end

create_table "lineitems", :force => true do |t|
  t.integer "cart_id"
  t.integer "part_id"
  t.integer "package_id"
  t.integer "quantity", :default => 1
  t.datetime "created_at", :null => false
  t.datetime "updated_at", :null => false
end

create_table "parts", :force => true do |t|
  t.string "description"
  t.string "partNumber"
  t.decimal "price"
  t.datetime "created_at", :null => false
  t.datetime "updated_at", :null => false
end

create_table "packages", :force => true do |t|
  t.string "description"
  t.string "name"
  t.string "img_src"
  t.decimal "price"
  t.datetime "created_at", :null => false
  t.datetime "updated_at", :null => false
end

上述表格有效,但......

问题 1:如何显示 package.name 而不是 :package_id

问题2:如何在表格中显示每个lineitem的total_price。这是一种如何工作的方法?

问题 3:是否有以发票外观方式显示表单的最佳做法,其中数量可能是文本字段,但其余列只是文本或标签?

最终游戏场景是此表单将是在提交订单之前编辑购物车数量(或删除订单项)的最后机会。显然,在现实世界中,您希望显示数量、包装名称、描述和价格,但我似乎无法弄清楚如何在表单中显示这些值,因为它们按关系位于另一个模型中,而不是特定于 lineitems。

谢谢您的帮助。

4

1 回答 1

0

您正在寻找 ActionView::Helpers::ActiveModelInstanceTag#object 方法。这使您可以访问表单内的任何地方的 ActiveRecord。

1

<% if f.object.package_id? %>
  <%= text_field_tag :package_name, f.object.package.name %>
  <%= f.hidden_field :package_id %>
<% else %>

2<%= f.object.total_price %>

3 也许尝试:readonly => true除数量之外的所有输入标签上的选项?

于 2012-08-03T17:08:07.253 回答