今天遇到一个有趣的问题,就是在用javascript的parseInt函数时,parseInt("08")或者parseInt("09")返回的居然是0,而parseInt("01")...parseInt("07")都是正确的,一开始很难理解,后来发现出现这个问题的原因是当在前面有"0"时,javascript会认为这是一个八进制数,而"08"和"09"不是一个合法的八进制数,所以导致了那个问题,但是parseFloat不会存在这个问题。
事实上,parseInt方法有一个可选参数来表示数字的进制,所以这应该不能算是一个bug,只是我们平时没有注意到这种细节问题。那么解决的方法很简单,就是使用parseInt("08",10)或者parseInt("09",10),通知javascript解释器使用十进制来解析就可以了。
下面是这个方法的说明:
parseInt()方法用于将一个字符串转换为整型数字。
语法:
parseInt(string, radix)
参数 | 描述 |
string | 必选项。所要转换的字符串 |
radix(进制) | 可选项。2到36,指定字符串的进制类型 |
注意:
- 只返回字符串的第一组连续数字
- 允许字符串包含空格
- 如果字符串的第一个字符不能被转换成数字,将返回NaN
- 如果没有指定进制参数,JavaScript将依照下列规则进行:
如果字符串以"0x"开始,视为16进制
如果字符串以"0"开始,视为8进制
其他的视为10进制
实例:
<script type="text/javascript">
document.write(parseInt("10") + "<br />");
document.write(parseInt("10.00") + "<br />");
document.write(parseInt("10.33") + "<br />");
document.write(parseInt("34 45 66") + "<br />");
document.write(parseInt(" 60 ") + "<br />");
document.write(parseInt("40 years") + "<br />");
document.write(parseInt("He was 40") + "<br />");
document.write("<br />");
document.write(parseInt("10")+ "<br />");
document.write(parseInt("10",10)+ "<br />");
document.write(parseInt("010")+ "<br />");
document.write(parseInt("10",8)+ "<br />");
document.write(parseInt("0x10")+ "<br />");
document.write(parseInt("10",16)+ "<br />");
document.write(parseInt("08")+ "<br />");
document.write(parseInt("08",10)+ "<br />");
</script>
输出结果:
10
10
10
34
60
40
NaN
10
10
8
8
16
16
0
8