String转换为Number有不少种方式,我能够想到的有5种!但总有一些状况让人猝不及防,总结到这里供本身往后查找方便
根据JsPerf.com的基准测试,大多数浏览器对parseInt的响应最佳。虽然它是最快的方式,但使用preseInt会碰到一些常见陷阱:parseInt: 没有传入基数时,默认是传入的基数为10 parseInt(num, 10),若是你不知道num属性的类型,不要使用parseInt进行字符串转数字。浏览器
parseInt('043') // returns 0 部分老浏览器. parseInt('20.mp4') // returns 20
若是你不解析16进制数,这是一个很是好的选择。字符串中的负十六进制数字是一个特殊状况,若是你用parseFloat解析,结果是不正确的。为了不程序出现NaN的状况,应该检查转化后的值。测试
parseInt(-0xFF) // returns -255 parseInt("-0xFF") // returns -255 parseFloat(-0xFF) // returns -255 parseFloat("-0xFF") // returns 0 parseFloat('44.jpg') // return 44
能够把字符串转换成整数,但他不是浮点数。若是是一个字符串转换,它将返回0;这是什么原理?经过翻转)每一个位,也称为数字的A1补码。你可使用它,但注意只能用来存储整数。因此一般状况不要用它,除非你能肯定这个数是在32位整数之间的值(由于调用的ToInt32的规范)。 按位非:用它确保输入中没有字符,仅用于整数。code
~~1.23 // returns 1 ~~"1.23" // returns 1 ~~"23" // returns 23 ~~"Hello world" // returns 0
Number与以上说起的转换方式同样存在这样的问题,解析时试图找出你给他的数字:注意:023其实是一个八进制数,不管你怎么作,都是返回19;对于没有单引号或双引号的十六进制数同样。Number也是JsPerf中最慢的之一。对象
Number("023") // returns 23 Number(023) // returns 19
"1.23" * 1 // returns 1.23 "0xFF" - 0 // returns 255 "0xFF.jpg" / 1 // returns NaN +"023" // returns 23
一元运算符与其它的解析方式不一样,若是是一个NaN值,那么返回的也是NaN 。这是我最喜欢的数值转换方式,由于我认为任何带有字符的对象都不该该被视为0或者根据他有多少位来“猜”。我基本使用 + 操做符,由于这个方式不容易混淆。虽然 -0 的用法也很好,但它并无很好的表达转换为数字的本意。字符串