【发布时间】:2011-06-01 15:20:14
【问题描述】:
JavaScript 中的parseInt(string) 和Number(string) 有什么区别?
【问题讨论】:
-
完整查看example。
标签: javascript string-conversion
JavaScript 中的parseInt(string) 和Number(string) 有什么区别?
【问题讨论】:
标签: javascript string-conversion
第一个有两个参数:
parseInt(string, radix)
radix参数用于指定使用哪种数字系统,例如基数为16(十六进制)表示字符串中的数字应从十六进制数解析为十进制数。
如果 radix 参数被省略,JavaScript 假设如下:
你提到的另一个函数只需要一个参数:
Number(object)
Number() 函数将对象参数转换为表示对象值的数字。
如果该值不能转换为合法数字,则返回 NaN。
【讨论】:
0x 或 0X 开头,在这种情况下,它被剥离并假定为 16。 (如果数字以 0 开头,则使用八进制从来不是标准的一部分,并且现在明确禁止 parseInt 从 ES2015 开始。)
parseInt("123qwe")
返回 123
Number("123qwe")
返回NaN
换句话说,parseInt() 解析到第一个非数字并返回它解析的任何内容。 Number() 想把整个字符串转成数字,顺便说一句,也可以是浮点数。
编辑#1:Lucero 评论了可以与parseInt() 一起使用的基数。就这一点而言,请参阅下面的THE DOCTOR's answer(我不会在这里复制,文档应该有相当的名气......)。
编辑#2:关于用例:这已经有点写在字里行间了。如果您想间接检查给定字符串是否完全表示数值、浮点数或整数,请使用Number()。 parseInt()/parseFloat() 并不那么严格,因为它们只是在数值停止时解析并停止(基数!),这在您需要前面的数值“以防万一”时非常有用(注意 @987654330 @ 也返回 NaN)。最大的不同是使用了Number() 不知道的基数,parseInt() 可能会从给定的字符串中间接猜测(有时会导致奇怪的结果)。
【讨论】:
parseInt()执行的格式检测(十六进制/八进制/十进制),这可能会导致严重的悲痛,因为它在某些情况下的行为与常见的预期不同(前导零)。因此,基数通常应明确指定,在将其与Number() 函数进行比较时更是如此。
parseInt("hui") 返回NaN
parseInt(string) 会将包含非数字字符的字符串转换为数字,只要该字符串以数字字符开头
'10px' => 10
Number(string) 如果字符串包含任何非数字字符,则返回 NaN
'10px' => NaN
【讨论】:
parseInt 函数允许您为输入字符串指定一个基数,并且仅限于整数值。
parseInt('Z', 36) === 35
作为函数调用的Number构造函数将使用语法解析字符串,并且限制为base 10和base 16。
@sjngm 回答的附录:
他们都忽略了空格:
var foo = " 3 ";
console.log(parseInt(foo)); // 3
console.log(Number(foo)); // 3
【讨论】:
@sjngm 回答的附录:
他们都忽略了空格:
var foo = " 3 "; console.log(parseInt(foo)); // 3 console.log(数字(foo)); // 3
这并不完全正确。正如 sjngm 所写,parseInt 将字符串解析为第一个数字。是真的。但问题是当你想解析用空格分隔的数字时,即。 “12345”。在这种情况下,parseInt("12 345") 将返回 12 而不是 12345。
因此,为避免这种情况,您必须在解析为数字之前修剪空格。
我的解决方案是:
var number=parseInt("12 345".replace(/\s+/g, ''),10);
请注意我在 parseInt() 函数中使用的另一件事。 parseInt("string",10) 会将数字设置为十进制格式。如果你要解析像 "08" 这样的字符串,你会得到 0,因为 8 不是八进制数。解释是 here
【讨论】: