JavaScript 中变态的 parseInt

本文探讨了JavaScript中parseInt函数的使用方法及特殊案例。当输入为08时,parseInt函数并不会如预期返回8,而是返回0。文章详细解释了parseInt的工作原理,并指出8不是有效的八进制数字。

alert(parseInt("08")) ,结果会是多少?

8?
10?

测试一下就知道了。看下parseInt的参考:

parseInt 方法

返回由字符串转换得到的整数。

parseInt(numString, [radix])

参数

numString

必选项。要转换为数字的字符串。

radix

可选项。在 2 和 36 之间的表示 numString 所保存数字的进制的值。如果没有提供,则前缀为 '0x' 的字符串被当作十六进制,前缀为 '0' 的字符串被当作八进制。所有其它字符串都被当作是十进制的。

说明

parseInt 方法返回与保存在 numString 中的数字值相等的整数。如果 numString 的前缀不能解释为整数,则返回 NaN(而不是数字)。

parseInt("abc")     // 返回 NaNparseInt("12abc")   // 返回 12

可以用 isNaN 方法检测 NaN

都错了。8进制不可能有8的。呵呵。测试了一下,返回0

### 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`。
评论 2
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值