我正在开发一个非常基本的购物车系统。
我有一个表items,它的列价格类型为整型。
我在视图中显示包含欧元和美分的价格时遇到了麻烦。在Rails框架中处理货币时,我是否遗漏了一些明显的东西?
我正在开发一个非常基本的购物车系统。
我有一个表items,它的列价格类型为整型。
我在视图中显示包含欧元和美分的价格时遇到了麻烦。在Rails框架中处理货币时,我是否遗漏了一些明显的东西?
当前回答
Ruby和Rails的简单代码
<%= number_to_currency(1234567890.50) %>
OUT PUT => $1,234,567,890.50
其他回答
我是这样用的:
number_to_currency(amount, unit: '€', precision: 2, format: "%u %n")
当然,货币的符号、精度、格式等都取决于每种货币。
如果有人正在使用Sequel,那么迁移将会是这样的:
add_column :products, :price, "decimal(8,2)"
Sequel忽略了:precision和:scale
续作版本:续作(3.39.0,3.38.0)
使用Virtual Attributes(链接到修订的(付费)Railscast),您可以将price_in_cents存储在一个整数列中,并在您的产品模型中添加虚拟属性price_in_dollars作为getter和setter。
# Add a price_in_cents integer column
$ rails g migration add_price_in_cents_to_products price_in_cents:integer
# Use virtual attributes in your Product model
# app/models/product.rb
def price_in_dollars
price_in_cents.to_d/100 if price_in_cents
end
def price_in_dollars=(dollars)
self.price_in_cents = dollars.to_d*100 if dollars.present?
end
来源:RailsCasts #016:虚拟属性:虚拟属性是添加不直接映射到数据库的表单字段的一种干净的方式。在这里,我将展示如何处理验证、关联等。
绝对的整数。
即使BigDecimal技术上存在,1.5仍然会在Ruby中给你一个纯浮点数。
Ruby和Rails的简单代码
<%= number_to_currency(1234567890.50) %>
OUT PUT => $1,234,567,890.50