JAVASCRIPT PARSEINT('08')

本文深入探讨了JavaScript中parseInt函数的工作原理,特别是它如何处理不同进制的数字字符串,以及当字符串以‘0’开头时可能出现的误解。

在javascript中将字符串转换成整数时,用到一个函数parseInt。这个函数完整的表达式是:

parseInt(string, radix)

 

一般情况下,都会省掉第二个参数radix。当遇到转换“0”开头的字符串的时候,问题就来了。

    parseInt("01") =1

              ~

    parseInt("07") =7

 

    parseInt("08") =0

    parseInt("09") =0

    parseInt("10") =10

 

这是为什么呢?

 

 

函数的第一个參數 string 當然是要轉換為數字的字串,第二個參數 radix 則是要用二進位、還是八進位或十六進位,又或是最熟悉的十進位來解譯這個字串呢?

也就是說,如果 parseInt('FF',16),代表以 16 進位方式來解析FF這個字串,當然得到的結果就是 255 了,同理,parseInt('FF',10) 以 10 進位來解析FF這個字串,根本就不是數字,所以得到的結果會是 NaN。

但大多數人不會特別指定第二個參數,這時 JavaScript 就自動判斷第一個傳遞的參數是否為某種數字型式。

在 JavaScript 眼中,以 0x 開頭的字串,都視為十六進位字串,如果單單是0開頭,第二個字母不是 x,則視為八進位或二進位字串,十六進位使用的字母計有 0-9,A-F,而八進位使用的字母則為 0-7,所以,當發生parseInt('08') 又未指定以何種數值型態解析時,JavaScript 以 0 為起頭,接下來的字母又不是 x,那一定是八進位了,但是,八進位裡,怎麼可能有 8 和 9 這兩個字母呢?所以,一定是不合法的字串,於是就傳回 0。

同理,parseInt('010') 回傳的值,也不是 10,而是 8,因為 parseInt() 認為 0 開頭,接下來的字母不是 x,而是 1,就以二進位來解析 010 這個字串,所以一切問題都在於以 0 開頭,所造成的誤會。

 

可以看出来,root cause就是字符串中以“0”开头了。万恶零开头。

 

解决办法
        
不能偷懒,该转换成什么进制就在第二个参数标明,如parseInt("08",10) = 8 这样就不会错了

 

<html>
<body>

<script type="text/javascript">


document.write("<br/>");
document.write("<br/>");
document.write( parseInt("abc")  + "<br/>");
document.write( parseInt("12abc")  + "<br/>");
document.write( parseInt("12")  + "<br/>");
document.write( parseInt("01")  + "<br/>");
document.write( parseInt("01")  + "<br/>");
document.write( parseInt("02")  + "<br/>");
document.write( parseInt("03")  + "<br/>");
document.write( parseInt("04")  + "<br/>");
document.write( parseInt("05")  + "<br/>");
document.write( parseInt("06")  + "<br/>");
document.write( parseInt("07")  + "<br/>");
document.write( parseInt("08")  + "<br/>");
document.write( parseInt("09")  + "<br/>");
document.write( parseInt("10")  + "<br/>");


document.write("<br/>");
document.write("<br/>");
document.write( parseInt("01",10)  + "<br/>");
document.write( parseInt("01",10)  + "<br/>");
document.write( parseInt("02",10)  + "<br/>");
document.write( parseInt("03",10)  + "<br/>");
document.write( parseInt("04",10)  + "<br/>");
document.write( parseInt("05",10)  + "<br/>");
document.write( parseInt("06",10)  + "<br/>");
document.write( parseInt("07",10)  + "<br/>");
document.write( parseInt("08",10)  + "<br/>");
document.write( parseInt("09",10)  + "<br/>");
document.write( parseInt("10",10)  + "<br/>");


</script>

</body>
</html>

 

结果:

 

NaN
12
12
1
1
2
3
4
5
6
7
0
0
10


1
1
2
3
4
5
6
7
8
9
10

 

 

### JavaScript 中 `parseInt` 函数的用法 `parseInt` 是用于解析字符串并返回整数的一个全局函数。该函数尝试将给定的字符串转换成一个指定基数(通常为十进制)下的整数值[^1]。 如果遇到无法识别为数字字符的部分,则停止解析,并返回已经成功解析到的结果部分作为整数。当输入为空或完全不可解析时,会返回 `NaN` (Not-a-Number)。 #### 基本语法 ```javascript parseInt(string, radix); ``` - **string**: 要被解析的字符串。 - **radix** *(可选)*: 表示要使用的进制系统的数字(介于 2 到 36)。如果不提供此参数,默认情况下将以十进制来解释数字;但如果字符串以 "0x" 开头则会被认为是十六进制,仅以零开头则是八进制。 #### 使用实例 下面是一些具体的例子展示如何使用 `parseInt()`: ```javascript console.log(parseInt('123')); // 输出: 123 console.log(parseInt('12.34')); // 输出: 12 console.log(parseInt('12a3b', 16)); // 输出: 29859 (因为'a'=10,'b'=11) console.log(parseInt('abc')); // 输出: NaN console.log(parseInt('0xF', 16)); // 输出: 15 console.log(parseInt('070')); // 输出: 56 (在某些环境中可能被认为是八进制) ``` 对于不带小数点的有效数字串,`parseInt` 可以正常工作并将它们转化为相应的整型值。然而需要注意的是,在处理带有前导零或其他特殊格式的情况下,可能会得到意想不到的结果,因此建议总是显式指明所需的进制系统。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值