任何数字,都是数字。字符串看起来像一个数字,它是数字。其他一切都是 NaN。
'a' => NaN
'1' => 1
1 => 1
任何数字,都是数字。字符串看起来像一个数字,它是数字。其他一切都是 NaN。
'a' => NaN
'1' => 1
1 => 1
据我所知,有4种方法可以做到。
Number(x);
parseInt(x, 10);
parseFloat(x);
+x;
通过我做的这个快速测试,它实际上取决于浏览器。
http://jsperf.com/best-of-string-to-number-conversion/2
Implicit
在 3 个浏览器上标记为最快,但它使代码难以阅读......所以选择你喜欢的任何东西!
如果您只想转换为整数,另一种快速(且简短)的方法是双位非(即使用两个波浪号字符):
例如
~~x;
参考:http : //james.padolsey.com/cool-stuff/double-bitwise-not/
到目前为止,我知道的将字符串转换为数字的 5 种常用方法都有其不同之处(有更多的按位运算符可以工作,但它们都给出与 相同的结果~~
)。此 JSFiddle 显示了您在调试控制台中可以预期的不同结果:http : //jsfiddle.net/TrueBlueAussie/j7x0q0e3/22/
var values = ["123",
undefined,
"not a number",
"123.45",
"1234 error",
"2147483648",
"4999999999"
];
for (var i = 0; i < values.length; i++){
var x = values[i];
console.log(x);
console.log(" Number(x) = " + Number(x));
console.log(" parseInt(x, 10) = " + parseInt(x, 10));
console.log(" parseFloat(x) = " + parseFloat(x));
console.log(" +x = " + +x);
console.log(" ~~x = " + ~~x);
}
123
Number(x) = 123
parseInt(x, 10) = 123
parseFloat(x) = 123
+x = 123
~~x = 123
undefined
Number(x) = NaN
parseInt(x, 10) = NaN
parseFloat(x) = NaN
+x = NaN
~~x = 0
null
Number(x) = 0
parseInt(x, 10) = NaN
parseFloat(x) = NaN
+x = 0
~~x = 0
"not a number"
Number(x) = NaN
parseInt(x, 10) = NaN
parseFloat(x) = NaN
+x = NaN
~~x = 0
123.45
Number(x) = 123.45
parseInt(x, 10) = 123
parseFloat(x) = 123.45
+x = 123.45
~~x = 123
1234 error
Number(x) = NaN
parseInt(x, 10) = 1234
parseFloat(x) = 1234
+x = NaN
~~x = 0
2147483648
Number(x) = 2147483648
parseInt(x, 10) = 2147483648
parseFloat(x) = 2147483648
+x = 2147483648
~~x = -2147483648
4999999999
Number(x) = 4999999999
parseInt(x, 10) = 4999999999
parseFloat(x) = 4999999999
+x = 4999999999
~~x = 705032703
该~~x
版本在“更多”情况下会产生一个数字,而其他情况下通常会产生undefined
,但它会因无效输入而失败(例如,0
如果字符串在有效数字之后包含非数字字符,则它将返回)。
请注意:整数溢出和/或位截断可能会发生在~~
,但不会发生在其他转换中。虽然输入如此大的值并不常见,但您需要注意这一点。示例已更新以包含更大的值。
一些 Perf 测试表明标准parseInt
和parseFloat
功能实际上是最快的选项,大概是浏览器高度优化的,但这一切都取决于您的要求,因为所有选项都足够快:http : //jsperf.com/best-of-string-to -数字转换/37
这一切都取决于性能测试的配置方式,因为某些显示 parseInt/parseFloat 会慢得多。
用+
运算符作为字符串的前缀。
console.log(+'a') // NaN
console.log(+'1') // 1
console.log(+1) // 1
将字符串转换为整数的一种快速方法是使用按位或,如下所示:
x | 0
虽然这取决于它的实现方式,但理论上它应该相对较快(至少与 一样快+x
),因为它会首先x
转换为数字,然后执行非常有效的 or。
这是一个简单的方法: var num = Number(str); 在这个例子中str是包含字符串的变量。您可以测试并查看它是如何工作的打开:Google chrome developer tools,然后转到控制台并粘贴以下代码。阅读评论以更好地了解转换是如何完成的。
// Here Im creating my variable as a string
var str = "258";
// here im printing the string variable: str
console.log ( str );
// here Im using typeof , this tells me that the variable str is the type: string
console.log ("The variable str is type: " + typeof str);
// here is where the conversion happens
// Number will take the string in the parentesis and transform it to a variable num as type: number
var num = Number(str);
console.log ("The variable num is type: " + typeof num);