如何解决为什么 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 指出 C 中存在类似的功能 https://en.cppreference.com/w/cpp/string/basic_string/stol
解决方法
顾名思义,parseInt
作为解析器,而不是转换器。当转换器将字符串作为一个整体并试图理解它时,解析器逐个符号使用输入并在它无法处理的第一个符号处停止。在 javascript 中,数字的转换器是 Number
:
console.log(Number('123foo'))
console.log(parseInt('123foo'))
在 C 中,atoi
、strtol
和类似的函数都是解析器,而不是转换器。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。