JavaScript 是弱类型语言,为了保证数值的有效性,在处理数值的时候,我们可以对数值字符串进行强行转换。如 parseInt 取整和 parseFloat 取浮点数。Java 也有 Integer.parseInt() 方法, 但是 JavaScript 的 parseInt 处理方式与 Java 等强整型语言不太一样, 所以经常有人因为对这个方法的使用不当而获得异常返回。

之前阿里巴巴的前端面试有一道这样的题,是关于parseInt()的用法的,题目如下:

var b = parseInt("01");
alert("b="+b);
var c = parseInt("09/08/2009");
alert("c="+c);

答案是b=1,c=0。

parseInt()是用来解析字符串,返回值是整数。有几个特点:

  1. 无视被解析字符串最前和最后的空格,即:" 111 "和"111"是一样的
  2. 正规格式是parseInt(string,radix)。radix可以省略,为0或者2-36之间的整数,用来表示被解析数值的进制。(注意不是解析返回结果的进制)。如果radix不在此范围内,返回NaN
  3. 如果radix 省略或者为0,则按默认进制对string进行解析。
  4. string的首字符为0,则默认解析为8进制。string首字符为0x则默认解析为16进制。其他情况默认为10进制。
  5. 解析从第一个可以解析的字符开始,到第一个不能解析的字符(如空格,标点符号等)结束。后面的字符不再解析。
  6. 如果第一个字符不可以解析,则返回NaN。如"a8989"

现在我们再回头来看这个题就容易理解了。

b的值首字母是0,按8进制解析后面的数值,也就是8进制的1。自然返回值为1。

难点在第二个。

c的首字符是0,一般想法是按8进制进行解析。但是我们发现第二个字符9已经不是8进制数,也就是说9是第一个不能解析的字符。parseInt("09/08/2009")也就变成了parseInt("0");结果再明显不过,是0。

如果我们稍加变化parseInt("0119/08/2009"),首字符是0,按八进制解析,同样读到9的时候不能解析。也就变成了parseInt("011"),结果也很明显,是9。

下面的代码大家可以自己测试一下,只要把等价的string写出来,结果就显而易见了。还有提示大家注意分辨网上杂乱的资料。不要被错误的分析误导。

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>test</title>
</head>
<body>
</body>
<script type="text/javascript">
document.write(parseInt("010","")+ "<br />");
document.write(parseInt("010","0")+ "<br />");
document.write(parseInt("10","2")+ "<br />");
document.write(parseInt("09/08/2009")+ "<br />");
document.write(parseInt("0119/08/2009")+ "<br />");
document.write(parseInt("03 0/aafsdfs")+ "<br />");
document.write(parseInt(" 030,aaf")+ "<br />");
document.write(parseInt("030aaf")+ "<br />");
document.write(parseInt("03/2009")+ "<br />");
document.write(parseInt("a03/2009")+ "<br />");
document.write(parseInt("0119/08/2009")+ "<br />");
</script>
</html>

一个例子:

parseInt("10");			//返回 10
parseInt("19",10); //返回 19 (10+9)
parseInt("11",2); //返回 3 (10+9)
parseInt("17",8); //返回 15 (8+7)
parseInt("1f",16); //返回 31 (16+15)
parseInt("010"); //未定:返回 10 或 8
05-11 19:50