学习
实践
活动
专区
工具
TVP
写文章

JavaScript字符串转数字的5种方法,还有你不知道的坑!

在JavaScript里面,String转换为Number有很多种方式,我可以想到的有下面的5种了!

看到那么多,很多小伙伴就会问了,我要选择哪一种呢?什么时候选择它?为什么选择它呢?

下面我们来逐一进行分析,并给大家简单说说每种方式的常见陷阱。

parseInt

根据JsPerf.com的基准测试,大多数浏览器对parseInt的响应最佳

虽然它是最快的方式,但使用preseInt会碰到一些常见陷阱

parseInt:没有传入基数时,默认是传入的基数为10parseInt(num, 10),如果你不知道num属性的类型,不要使用parseInt进行字符串转数字。

parseFloat

如果你不是解析16进制数,这是一个非常好的选择。例如:

注意:字符串中的负十六进制数字是一个特殊情况,如果你用parseFloat解析,结果是不正确的。为了避免程序出现NaN的情况,应该检查转化后的值。

parseFloat:转换十六进制数时要小心,如果你不知道要转换对象的类型,不要使用parseFloat。

按位非

可以把字符串转换成整数,但他不是浮点数。如果是一个字符串转换,它将返回0;

这是什么原理?通过翻转)每个位,也称为数字的A1补码。

你可以使用它,但注意只能用来存储整数。

所以通常情况不要用它,除非你能确定这个数是在32位整数之间的值(因为调用的ToInt32的规范)。

按位非:用它确保输入中没有字符,仅用于整数。

Number

Number与以上提及的转换方式一样存在这样的问题,解析时试图找出你给他的数字:

注意:023实际上是一个八进制数,无论你怎么做,都是返回19;对于没有单引号或双引号的十六进制数一样。

Number也是JsPerf中最慢的之一。

Number:几乎不用它。

一元运算符

一元运算符与其它的解析方式不同,如果是一个NaN值,那么返回的也是NaN 。

这是我最喜欢的数值转换方式,因为我认为任何带有字符的对象都不应该被视为0或者根据他有多少位来“猜”。

我基本使用+操作符,因为这个方式不容易混淆。

虽然-0的用法也很好,但它并没有很好的表达转换为数字的本意。

字符串转换为数字的方式总结

负十六进制数字符串转换为数字时。

应首先将任何其转换为String(例如通过+ ""),然后使用一元运算符或带基数的parseInt解析为数字。

但是结果不是NaN的数值时,使用parseFloat更为合适。

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20180710A0FXDS00?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

关注

腾讯云开发者公众号
10元无门槛代金券
洞察腾讯核心技术
剖析业界实践案例
腾讯云开发者公众号二维码

扫码关注腾讯云开发者

领取腾讯云代金券