保留小数点后四位,且去除多余0,举几个例子:
12.31564798798 =====> 12.3156
52.5649813546 =====> 52.565
102.5999999999 =====> 102.6
即四舍五入至小数点后第四位,且去除最后无意义的0;
JS四舍五入的方法有:
parseInt(5/2) //2 丢弃小数部分,保留整数部分
Math.ceil(5/2) //3 向上取整,有小数,则整数部分加1
Math.round(5/2) //3 四舍五入
Math.floor(5/2) //2 向下取整
toFixed(num)方法, num的值为0-20,把数值四舍五入至num位,不够补足。
Angularjs取两位小数:
使用filter过滤器;{{val | number:2}}
val = 1234.56789
保留0位:1235;
保留10位:1234.5678900000;
保留2位:1234.57;
===========分割线=========
但是,上面都不能同时保证即四舍五入,又去除末尾的0
有一个比较简单的方法:
var new = Math.round(val*10000)/10000;
保留val后面的4位小数,且去除多余0。
============2016/09/14==============
今天看《JavaScript高级程序设计》看到一个类似的问题,为什么js中(0.1+0.2 != 0.3),而是0.30000000000000004.
工作中碰到的问题类似,333.4*24结果本应该是8001.6,但是js处理的结果是8001.599999999999.
用上面的一系列方法,得到的结果都是8001.6000,略忧桑。。。。。。
刚好今天查了下原因,知乎的一个帖子描述得不错,包括解决方法也有,链接
链接:http://www.zhihu.com/question/24415787/answer/57187211
来源:知乎
著作权归作者所有,转载请联系作者获得授权。
js中的数字都是用浮点数表示的,并规定使用IEEE 754 标准的双精度浮点数表示。
IEEE 754 规定了两种基本浮点格式:单精度和双精度。
IEEE单精度格式具有24 位有效数字精度(包含符号号),并总共占用32 位。
IEEE双精度格式具有53 位有效数字精度(包含符号号),并总共占用64 位。
十进制0.1
=> 二进制0.00011001100110011…(循环0011)
=>尾数为1.1001100110011001100…1100(共52位,除了小数点左边的1),指数为-4(二进制移码为00000000010),符号位为0
=> 计算机存储为:0 00000000100 10011001100110011…11001
=> 因为尾数最多52位,所以实际存储的值为0.00011001100110011001100110011001100110011001100110011001
而十进制0.2
=> 二进制0.0011001100110011…(循环0011)
=>尾数为1.1001100110011001100…1100(共52位,除了小数点左边的1),指数为-3(二进制移码为00000000011),符号位为0
=> 存储为:0 00000000011 10011001100110011…11001
因为尾数最多52位,所以实际存储的值为0.00110011001100110011001100110011001100110011001100110011
那么两者相加得:
0.00011001100110011001100110011001100110011001100110011001
+ 0.00110011001100110011001100110011001100110011001100110011
= 0.01001100110011001100110011001100110011001100110011001100
转换成10进制之后得到:0.30000000000000004