我正在开发一个非常基本的购物车系统。
我有一个表items,它的列价格类型为整型。
我在视图中显示包含欧元和美分的价格时遇到了麻烦。在Rails框架中处理货币时,我是否遗漏了一些明显的东西?
我正在开发一个非常基本的购物车系统。
我有一个表items,它的列价格类型为整型。
我在视图中显示包含欧元和美分的价格时遇到了麻烦。在Rails框架中处理货币时,我是否遗漏了一些明显的东西?
当前回答
如果有人正在使用Sequel,那么迁移将会是这样的:
add_column :products, :price, "decimal(8,2)"
Sequel忽略了:precision和:scale
续作版本:续作(3.39.0,3.38.0)
其他回答
我的底层api都使用美分来表示钱,我不想改变这一点。我也没有大量的资金。我把这个放到helper方法中
sprintf("%03d", amount).insert(-3, ".")
它将整数转换为至少有三位数字的字符串(必要时添加前导零),然后在最后两位数字之前插入一个小数点,从不使用Float。从这里,您可以添加任何适合您的用例的货币符号。
这绝对是快速和肮脏的,但有时这是好的!
绝对的整数。
即使BigDecimal技术上存在,1.5仍然会在Ruby中给你一个纯浮点数。
Ruby和Rails的简单代码
<%= number_to_currency(1234567890.50) %>
OUT PUT => $1,234,567,890.50
如果你正在使用Postgres(因为我们现在已经是2017年了),你可能想尝试一下他们的:money列。
add_column :products, :price, :money, default: 0
如果有人正在使用Sequel,那么迁移将会是这样的:
add_column :products, :price, "decimal(8,2)"
Sequel忽略了:precision和:scale
续作版本:续作(3.39.0,3.38.0)