javascript - 问一个有趣的问题: 如何将 数字 转成 金额格式
问题描述
最近做业务,碰到一个有趣的问题:
服务端 为了计算金钱准确,把金钱都转换成 分单位( 1元 = 100 )
到前端需要把它转换成 金钱格式 159 => 1.59元
看了下项目中 实现办法是使用 tofixed 来实现的,不过,有bug。
要求
159 -> 1.59元1500 -> 15.00 元88 -> 0.88元8 -> 0.08元
另外 有的时候显示形式是 (元 大一些,分 小一些)
问题解答
回答1:一个简单的示例如下:
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’回答2:
function toPrice(d){return `00${d}`.replace(/(.*)(d{2})/g,’$1.$2元’).replace(/0*([1-9]*d..*)/,’$1’)}回答3:
(1232/100).toLocaleString()
相关文章:
1. docker网络端口映射,没有方便点的操作方法么?2. c++ - QWebEngineView加载url后直接点击链接没有反应要怎么解决?3. android - Gradle慢成xx了4. mysql - 我的myeclipse一直连显示数据库连接失败,不知道为什么5. 为什么redis中incr一个“0” 会报错?6. python爬虫 - scrapy使用redis的时候,redis需要进行一些设置吗?7. 前端HTML与PHP+MySQL连接8. 看不懂你这一步的操作9. html - vue项目中用到了elementUI问题10. mysql_replication - mysql读写分离时如果单台写库也无法满足性能怎么解决

网公网安备