<>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是对字符串进行作用的