首页 > 解决方案 > 为什么 Number.parseInt('111AAA') 像它在 JS 中那样工作?这种行为背后的原因是什么?

问题描述

如果我执行parseInt('111AAA'),我们会得到输出'111'。在 javascript 中,为什么 parseInt 像 MDN 文档中提到的那样工作。

parseInt 函数将其第一个参数转换为字符串,对其进行解析,并返回一个整数或 NaN。如果不是 NaN,则返回值将是第一个参数的十进制整数表示形式,该参数采用指定基数(基数)中的数字。例如,基数 10 表示从十进制数、8 位八进制数、16 位十六进制数等转换。对于大于 10 的基数,字母表中的字母表示大于 9 的数字。例如,对于十六进制数(以 16 为基数),使用 A 到 F。

如果 parseInt 在指定的基数中遇到不是数字的字符,它会忽略它和所有后续字符并返回解析到该点的整数值。parseInt 将数字截断为整数值。允许前导和尾随空格。

我已经开始学习 JS 并且有使用 Java 和 C 的背景。如果提供给它的字母数字值不应该给出错误。这种行为背后的原因是什么?有没有其他语言采用这种方式?

编辑:@jabaa https://en.cppreference.com/w/cpp/string/basic_string/stol指出 C 中存在类似的功能

标签: javascriptecmascript-2017ecma

解决方案


顾名思义,parseInt作为解析器,而不是转换器。当转换器将字符串作为一个整体并试图理解它时,解析器会逐个符号地使用输入符号并在它无法处理的第一个符号处停止。在 javascript 中,数字的转换器是Number

console.log(Number('123foo'))
console.log(parseInt('123foo'))

在 C 中atoistrtol和类似的函数都是解析器,而不是转换器。


推荐阅读