js数值四舍五入的方法以及其中潜在bug的解决方案

1.toFixed() 方法可把 Number 四舍五入为指定小数位数的数字。

NumberObject.toFixed(num)
num必需写,规定小数的位数,是 0 ~ 20 之间的值,包括 0 和 20,有些实现可以支持更大的数值范围。如果省略了该参数,将用 0 代替。

当num超过20的时候,js会出错,这东西好像只能传一个数字进去,字符串会爆不是一个方法

方法存在的bug:

Number(13.35).toFixed(1); //13.3 
Number(0.055).toFixed(1); //0.1
原因:原生toFixed(x)截取小数的时候会有误差
//如果要修改这个缺陷,可以把js中的number类型的tofixed方法重写。

2.Math.round() 方法可把一个数字舍入为最接近的整数。

Math.round(x)
x为需要计算的数值。该方法 返回与给出的数值表达式最接近的整数。

方法个存在的bug

Math.round(num * Math.pow(10, 2)) / Math.pow(10, 2);  //num是待处理数字Math.pow(10, 2)=100

当num = 10.10500时,计算上述表达式可得10.11。(正常)
当num = "10.50000"时(注意这里是字符串),计算上述表达式可得10.5。(damn it,小数点后位数不对!)
原因:当num是字符串,进行乘法操作时,进行了类型转换,后缀零被丢弃了,导致位数不足,这个时候我们就应该进行补0
 
  

解决方案:

var iTofixed =function(num,fractionDigits) {
return (Math.round(num*Math.pow(10,fractionDigits))/Math.pow(10,fractionDigits)+Math.pow(10,-(fractionDigits+1))).toString().slice(0, -1)
};
iTofixed('13.5000',3);
//"13.500"

你可能感兴趣的:(前端技术知识)