问一个有趣的问题: 如何将 数字 转成 金额格式

最近做业务,碰到一个有趣的问题:

服务端 为了计算金钱准确,把金钱都转换成 分单位( 1元 = 100 )

到前端需要把它转换成 金钱格式 159 => 1.59元

看了下项目中 实现办法是使用 tofixed 来实现的,不过,有bug。

要求

159 -> 1.59元
1500 -> 15.00 元

88 -> 0.88元
8 -> 0.08元

另外 有的时候显示形式是 (元 大一些,分 小一些)

回复
阅读 4.5k
3 个回答

一个简单的示例如下:

function convertUnit (value) {
  // bug 常见出现自 parseInt 未指定进制
  return parseFloat(parseInt(value, 10) / 100).toFixed(2) + '元'
}

简单的测试用例:

> parseFloat(169 / 100).toFixed(2)
'1.69'
> parseFloat(8 / 100).toFixed(2)
'0.08'
> parseFloat(88 / 100).toFixed(2)
'0.88'
> parseFloat(1500 / 100).toFixed(2)
'15.00'
function toPrice(d){
return `00${d}`.replace(/(.*)(\d{2})/g,'$1\.$2元').replace(/0*([1-9]*\d\..*)/,'$1')
}
(1232/100).toLocaleString()
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
宣传栏