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

技术
今日推荐
下载桌面版
GitHub
百度网盘(提取码:draw)
Gitee
云服务器优惠
阿里云优惠券
腾讯云优惠券
华为云优惠券
站点信息
问题反馈
邮箱:[email protected]
QQ群:766591547
关注微信