Day4
如何优雅得分解出整数和小数
取整数方法
1.praseInt()函数解释
第一个参数是字符串,如果不是字符串就将它先转为字符串,之后进行转换(取整)
因为这个点他多此一举,要额外转成字符串照成一定性能开销
第二个参数是转换的进制数,默认为10
所以实际上parseInt(3.75)
这个代码,会先将3.75转为字符串"3.75",然后再将它parseInt成为3
parseFloat('123abc')
结果是123,因为 parseFloat 会尝试转部分数值,而忽略掉不能转数值的部分。
2.使用 Math 库
实际上,在ES2015之后,还提供了原生的Math.trunc
,我们可以更方便地使用 Math.trunc,不用自己使用 Math.floor 和 Math.ceil 去实现了:
console.log(Math.trunc(3.75)); // 3
console.log(Math.trunc(-3.75)); // -3
下面是自己对 trunc 的实现
用Math的方法来取整,相关的有3个方法,分别是 Math.ceil、 Math.round 和 Math.floor。
其中 Math.round 是四舍五入的,Math.ceil 是向上取整,Math.floor 是向下取整。
要达到 parseInt 的结果,我们需要判断数值的符号,如果是负数,要使用 Math.ceil,如果是正数,则使用 Math.floor:
function trunc(num) {
if(num >= 0) return Math.floor(num);
return Math.ceil(num);
}
console.log(trunc(3.75)); // 3
console.log(trunc(-3.75)); // -3
3.tricky
使用按位或“|”
来取整
let num = 3.75;
console.log(num | 0); // 3
num = -num;
console.log(num | 0); // -3
但有问题,因为按位操作将操作数转为Int32,所以它不能处理超过32位的数值取整,而JavaScript有效整数的范围是53位。
const num = 17179869184.89;
console.log(num | 0); // 0
console.log(Math.trunc(num)); // 17179869184
那么用“|”有什么好处呢?如果考虑js文件大小,那么a|0与其他方式比较,是最短的方式,所以如果要考虑压缩代码的大小,且明确知道数值范围不会超过32位整数的时候,可以考虑使用这个技巧。
取小数方法
1.原数字减去整数
2.取模
JavaScript的取模运算%并不限于整数运算,可以对浮点数取模。
console.log(3.75 % 1); // 0.75
console.log(-3.75 % 1); // -0.75
BTW :split是对字符串进行作用的