重新认识parseInt函数

前段时间做了一个简易的计算器,其中有用到利用parseInt函数,将字符串转换成数字。由于以前并没有系统的学习过parseInt这个函数,所以在制作的过程中遇到了一些问题。

打开电脑自带的计算器可以发现,有个默认的数字0,当点击下面的数字会相应的改变,因为输入框中显示的数字的类型是字符串,所以在进行运算符运算的时候需要转成数字,于是就用到了parseInt函数,同时问题也就出现了。点击0-7数字可以正常显示其数字,但是当点击8和9时显示的是0,这是为何,百思不得其解?

通过w3school查找,发现原来 parseInt() 有两个参数,第一参数是要转换的字符串,而第二个参数是一个基数,表示多少进制。其中有一段说明:当第二个参数为0或者没有时,parseInt() 会根据 string 来判断数字的基数。如果 string 以 "0x" 开头,parseInt() 会把 string 的其余部分解析为十六进制的整数。如果 string 以 0 开头,那么 ECMAScript v3 允许 parseInt() 的一个实现把其后的字符解析为八进制或十六进制的数字。如果 string 以 1 ~ 9 的数字开头,parseInt() 将把它解析为十进制的整数。

因为是字符串相加,所以刚开始默认 ‘0’ 加上 ‘8’ 会变成 ‘08’,而 parseInt('08') 根据上面的说明进行八进制转换成0,不是我所认为的十进制转换成8。只需要改成 parseInt('08',10) 就可以解决问题了。

PS:通常我们的习惯是不写第二个参数的,所以有时候会造成一些莫名其妙的问题。

PS2:博客搬家了,以后不再 CSDN 更新了,见谅。最新博客地址:http://www.cnblogs.com/yjzhu/

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章