JS中parseInt('08')的一个问题

        Javascript中parseInt("08")返回的值会是什么,0还是8 ?如果你的回答是8 ,那么你就应该注意一下将会提到的这个不算是问题的问题。
        以前在项目中遇到这个问题,在日期处理的时候需要对用户选择的月份(两位的字符串)进行转化和计算,然而选择8月或9月时计算出的结果是错误的,后来调试的时候发现parseInt函数引起的。parseInt("01")到parseInt("07")都能返回正确的数值,而parseInt("08")和parseInt("09")返回的值却都是0。
查找了JS的文档后发现这个问题发生的原因是前面的"0",parseInt方法有一个可选参数来表示数字的进制,以"0"作为首字符的字符串会被JS识别为八进制数并将没有指定数字进制参数的参数值默认为8,从而以八进制来解析字符串,而"08"和"09"都不是合法的八进制数,所以被解析为0。

实际上,这是个不注意细节引起的问题,显式设置进制参数的parseInt根本不会出现这个问题,parseInt("08",10)或parseInt("09",10)都能返回正确的数值。另外,parseFloat不会存在这个问题。


### parseInt 函数的详细说明 在 JavaScript 中,`parseInt()` 是一个用于将字符串转换为整数的全局函数。该函数接受两个参数:需要解析的字符串和表示数值进制的基数(radix)。如果未指定 radix,则会根据字符串内容自动推断[^1]。 #### 基本语法 ```javascript parseInt(string, radix); ``` - **string**:要被解析的字符串。 - **radix**:可选参数,表示解析时使用的进制(例如 2 表示二进制,10 表示十进制,16 表示十六进制等)。 如果 `radix` 被省略,`parseInt` 会尝试根据字符串的内容自动选择合适的进制。例如,以 "0x" 开头的字符串会被视为十六进制数[^1]。 #### 示例代码 以下是一些使用 `parseInt` 的示例: ```javascript // 十进制转换 console.log(parseInt("123", 10)); // 输出: 123 // 十六进制转换 console.log(parseInt("0xFF", 16)); // 输出: 255 // 二进制转换 console.log(parseInt("1010", 2)); // 输出: 10 // 自动推断进制(不推荐) console.log(parseInt("010")); // 输出: 8 (在某些环境中可能被认为是八进制) // 非法输入 console.log(parseInt("abc", 10)); // 输出: NaN ``` 当字符串中包含非数字字符时,`parseInt` 会从字符串开头开始解析,直到遇到无法解析的字符为止[^1]。例如: ```javascript console.log(parseInt("123abc", 10)); // 输出: 123 console.log(parseInt("abc123", 10)); // 输出: NaN ``` #### radix 参数的重要性 选择正确的 `radix` 对于确保正确解析至关重要。例如,在处理用户输入时,如果不指定 radix,可能会导致意外结果。例如,字符串 "prompt" 中的最大字母是 "t",为了将其完全解析为整数,radix 应至少为 30(因为 A-T 共 20 位加上 0-9 的 10 位)[^2]。 ```javascript console.log(parseInt("prompt", 30)); // 输出: 7473549 ``` #### 处理非法输入 当字符串无法被解析为有效的整数时,`parseInt` 返回 `NaN`(Not-a-Number)。可以结合 `isNaN()` 函数来检查返回值是否有效: ```javascript let result = parseInt("xyz", 10); if (isNaN(result)) { console.log("无效的输入"); } else { console.log(result); } ``` ### 注意事项 - 如果字符串为空或仅包含空格,`parseInt` 将返回 `NaN`[^1]。 - 当 radix 参数超出范围(小于 2 或大于 36),`parseInt` 将返回 `NaN`。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值