js保留两位小数的合理处理方法
发表于:2021-07-14 09:03:25浏览:3714次
js如何保留两位或者多位小数?相信大家的第一反应可能是使用 toFixed() 方法,但是使用这个方法在小数位不足的情况下会在后面补 0,比如:
const num = 0.6; num.toFixed(2) // 0.60
严格来说,这个结果是不符合要求的,还有一个需要注意的问题,js的运算属于弱运算,小数的相加结果可能并不符合预期,相信很多开发者也碰到过,比如:
console.log(0.2 + 0.4) // 0.6000000000000001
所以这里建议使用 Math.floor() 方法来处理小数位比较合适,先给结果乘以 100,再通过 Math.floor() 取得整数部分,然后再除以 100,最后得到符合要求的结果,比如:
const num1 = 0.5; const num2 = 0.62352; Math.floor(num1 * 100)/100 // 0.5 Math.floor(num2 * 100)/100 // 0.62
如果要保留更多为小数就以此类推了,比如保留三位小数:
const num1 = 0.5; const num2 = 0.55; const num3 = 0.62352; Math.floor(num1 * 1000)/1000 // 0.5 Math.floor(num2 * 1000)/1000 // 0.55 Math.floor(num3 * 1000)/1000 // 0.623
虽然过程比toFixed方法多了一个处理步骤,但是得到的结果更理想。
推荐文章
- 82个常规的前端JavaScript方法封装(11~20)
- Layui的upload模块实现多图批量上传,无需修改代码,完美解决方案
- Thinkphp6集成JWT API接口引入token
- ref, toRef, toRefs,reactive, defineComponent, computed, unref, toRaw, watchEffect, onUpdated 10个VUE3前端API总结
- CSS @media print控制浏览器web打印样式
- 一个简单的thinkphp6的路由配置实例
- 微软宣布Windows 11将于2021年10月5日上市
- Thinkphp8通过PhpWord导出生成word文件,支持图片处理,富文本导出完整方案
- Layui的laydate模块实现快捷选中今天、昨天 、本周、本月等操作
- 如何给OA系统加上名字工号的水印?其实很简单,WEB前端就能实现添加水印

