JavaScript parseInt0.0000005打印5原理解析
目录
- 前言
- 1.什么时候使用parseInt?
- 2.关于parseInt的一些事情
- 语法
- 例子
- 3. parseInt 是如何转换数字的?
- 3.1 第一步?将数字转换为字符串
- 3.2 第二步,做舍入操作
- 4. 如何安全获取浮点数的整数部分?
- 5. 举一反三
前言
最近,我在开发项目时遇到了一个奇怪的问题,parseInt (0.0000005) === 5。通常,输出 0 才是正确的,但为什么是 5?让我们一起探讨这个问题。
1.什么时候使用parseInt?
首先,您通常什么时候使用parseInt?大多数时候,我们使用它来解析字符串并返回它的整数部分。带着这个问题,我们来看看parseInt方法。
2.关于parseInt的一些事情
根据 MDN文档,“parseInt(string, radix) 函数解析字符串参数并返回指定基数(数学数字系统中的基数)的整数。”
语法
parseInt(string) parseInt(string, radix)
例子
parseInt('0.5') // 0 parseInt('0.5') // 0 parseInt('0.05') // 0 parseInt('0.005') // 0 parseInt('0.0005') // 0 parseInt('0.00005') // 0 parseInt('0.000005') // 0 parseInt('015') // 15 parseInt('015', 8) // 13 parseInt('15px', 10) // 15
3. parseInt 是如何转换数字的?
当parseInt的第一个参数是一个数字时,它是如何解析的?
事实上在这里: parseInt(0.0000005) === 5
3.1 第一步?将数字转换为字符串
让我们使用 String 函数检查基于字符串的值,看看每个值的输出是什么
String(0.5); // => '0.5' String(0.05); // => '0.05' String(0.005); // => '0.005' String(0.0005); // => '0.0005' String(0.00005); // => '0.00005' String(0.000005); // => '0.000005' String(0.0000005); // => '5e-7' 请注意这里
3.2 第二步,做舍入操作
当我们使用 parseInt(0.0000005) 时,它实际等于 parseInt('5e-7')
parseInt 只能将字符串的前导部分解释为整数值;它忽略任何不能被解释为整数表示法的一部分的代码单元,并且没有给出任何这样的代码单元被忽略的指示。
parseInt(0.0000005) parseInt('5e-7') // 5
最后,答案将返回 5,只是因为它是唯一一个在非字符 e 之前是数字的字符,所以其余的 e-7 将被丢弃。”
4. 如何安全获取浮点数的整数部分?
推荐使用以下 Math.floor() 函数
Math.floor(0.5); // => 0 Math.floor(0.05); // => 0 Math.floor(0.005); // => 0 Math.floor(0.0005); // => 0 Math.floor(0.00005); // => 0 Math.floor(0.000005); // => 0 Math.floor(0.0000005); // => 0
5. 举一反三
现在,你能解释一下为什么 parseInt(99999999999999999999999999) 等于 1 吗?
以上就是JavaScript parseInt0.0000005打印5原理解析的详细内容,更多关于JavaScript parseInt打印原理的资料请关注我们其它相关文章!
赞 (0)