rails方法来计算小计和总计

Posted

技术标签:

【中文标题】rails方法来计算小计和总计【英文标题】:rails way to calculate subtotal and total 【发布时间】:2011-10-16 02:38:43 【问题描述】:

上下文:我有 2 个模型 Order 和 Item。

我想根据 item.quantity * item.price 计算项目小计 目前这是在视图中完成的(但不是在适当的位置)。

<%= number_to_currency(item.quantity * item.price) %>

我还需要计算订单总数,但我卡住了。我没有任何专栏。 最好的方法是什么?使用模型?助手还是观察者?

现在我设法通过订单助手进行小计工作

def item_subtotal(item)
  item_subtotal = item.quantity * item.price
end

工作解决方案:

物品模型

def subtotal
  price * quantity
end

在视图中渲染&lt;%= item.subtotal %&gt;

订单型号

def total_price
  total_price = items.inject(0)  |sum, p| sum + p.subtotal 
end

Order#show 视图渲染&lt;%= number_to_currency(@order.total_price) %&gt;

【问题讨论】:

【参考方案1】:

在您的 Item 模型上,您可以添加小计方法:

def subtotal
  quantity * price
end

假设您将 Order 模型作为与 Item 的 has_many 关系,您可以map 集合以获取 Order 模型上的价格列表:

def subtotals
  items.map do |i| i.subtotal end
end

因为您在 Rails 环境中运行,所以可以使用 activesupport sum 方法来获取 Order 模型的总数:

def total
  subtotals.sum
end

或者,如果您更喜欢将它们放在一起:

def total
  items.map do |i| i.subtotal end.sum
end

然后您可以在视图中使用 Item 的小计和 Order 的总计。

编辑:视图可能如下所示:

<% for item in @order.items %> <%= item.price %><br/><% end %>
<%= @order.total %>

【讨论】:

【参考方案2】:

既然是模型的一个功能(你想计算一些自引用的项目),更合适的位置是模型本身,这样你就可以轻松使用

item.subtotal

【讨论】:

哪种型号:订单或商品?它怎么知道小计等于价格 * 数量?总计呢? 小计应该在Item模型中定义,而总计应该在Ordertotal中通过选择所有项目并计算它们的小计来计算。 你能写一个例子来说明总体,特别是如何在视图中渲染。谢谢。 order#show 视图是这样的&lt;% for item in @order.items %&gt; &lt;%= item.price %&gt;【参考方案3】:

您可以使用显示 item_subtotal

对于总计,您可以通过以下方式计算它

total_price = @order.items.to_a.sum |item|总计 = item.product.price*item.quantity

我认为这对你有用。

【讨论】:

以上是关于rails方法来计算小计和总计的主要内容,如果未能解决你的问题,请参考以下文章

使用小计和总计的计算

计算所有项目总计到小计 Jquery

表 Javascript 中的小计和总计数

在 Shiny 中将总计/小计添加到数据表的底部

c#怎么计算Datatable里面数据的合计和总计

触发计算小计