如果你忽略parseInt的第二个参数,那么数字的基数将由下面的规则所决定:
◆ 默认基数为10,即按10进制解析
◆ 如果数字以0x开头,那么基数为16,即按16进制解析
◆ 如果数字以0开头,那么基数为8,即按8进制解析
一个常见的错误是我们让用户输入以0开头的数字,这时候它就按8进制的方式去解析了,于是我们就看到了如下的效果:
parseInt("8"); //8 parseInt("08"); //0 因此,我们很多时候都会指定parseInt的第二个参数,如下所示:
parseInt("8", 10); //8 parseInt("08", 10); //8 ECMAScript5方面的说明:ECMAScript已不再支持8进制的解析假设,另外,如果忽略parseInt的第二个参数将会引起JSLint的警告。
◆ 默认基数为10,即按10进制解析
◆ 如果数字以0x开头,那么基数为16,即按16进制解析
◆ 如果数字以0开头,那么基数为8,即按8进制解析
一个常见的错误是我们让用户输入以0开头的数字,这时候它就按8进制的方式去解析了,于是我们就看到了如下的效果:
parseInt("8"); //8 parseInt("08"); //0 因此,我们很多时候都会指定parseInt的第二个参数,如下所示:
parseInt("8", 10); //8 parseInt("08", 10); //8 ECMAScript5方面的说明:ECMAScript已不再支持8进制的解析假设,另外,如果忽略parseInt的第二个参数将会引起JSLint的警告。