如果你忽略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的警告。
本文探讨了在JavaScript中使用parseInt函数时忽略第二个参数的解析规则,包括默认基数为10、以0x开头按16进制解析、以0开头按8进制解析,并解释了这种行为可能导致的误解和JSLint警告。同时,通过实例演示了正确指定基数的重要性。
2896

被折叠的 条评论
为什么被折叠?



