JavaScript 保留两位小数

当我们遇到小数点加减乘除运算时,会产生多位数和计算精度丢失的情况,这是因为js是按照二进制来处理小数的加减乘除,在arg1基础上将arg2的精度进行扩展或逆扩展匹配。

在解决小数点的这个精度问题之前我们需要熟悉几个javascript处理小数的方法:

toFixed( )               把Number四舍五入为指定小数位数的数字

Math.ceil( )            向上取整,有小数整数部分加1

Math.floor( )          向下取整,有小数就把小数部分舍弃

Math.round( )        把数字舍入为最接近的整数

接下来给大家看几个奇怪的关于js计算小数的结果:

JavaScript 保留两位小数_第1张图片

结果都很出乎意料,所以在进行小数点的加减运算时,我们要保留两位小数。下面介绍javascript保留两位小数的几种实现方法:

1 四舍五入 toFixed(2)方法:

注意计算处理过后的结果都变成了String类型

JavaScript 保留两位小数_第2张图片

2 不四舍五入 Math.floor( )方法:

先把小数变成整数,然后用Math.floor( )方法向下取整舍弃小数,在除以100

JavaScript 保留两位小数_第3张图片

3 不四舍五入 先转换为字符串在用正则匹配截取两位小数,再转化为数字

Number(15.7733333333.toString().match(/^\d+(?:\.\d{0,2})?/)) 

JavaScript 保留两位小数_第4张图片

如果想更深入的了解关于js中小数点的问题,请参考下边这篇文章。

http://www.jb51.net/article/85463.htm





你可能感兴趣的:(js小技巧,JS)