JavaScript字符串转数字的5种方法及其陷阱

摘要 :JavaScript 是一个神奇的语言,字符串转数字有 5 种方法,各有各的坑法!javascript

本文采用意译,版权归原做者全部java

String 转换为 Number 有不少种方式,我能够想到的有 5 种!小程序

parseInt(num); // 默认方式 (没有基数)
parseInt(num, 10); // 传入基数 (十位数)
parseFloat(num); // 浮点数
Number(num); // Number 构造器
~~num; //按位非
num / 1; // 除一个数
num * 1; // 乘一个数
num -
0 + // 减去0
    num; // 一元运算符 "+"

选择哪种呢?何时选择它?为何选择这种它?咱们逐一进行分析,并解析每种方式的常见陷阱。微信小程序

parseInt

根据 JsPerf.com 的基准测试,大多数浏览器对 parseInt 的响应最佳。虽然它是最快的方式,但使用 preseInt 会碰到一些常见陷阱:浏览器

parseInt("08"); // returns 0 部分老浏览器.
parseInt("44.jpg"); // returns 44

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

parseFloat

若是你不解析 16 进制数,这是一个很是好的选择。例如:测试

parseInt(-0xff); // returns -255
parseInt("-0xFF"); // returns -255
parseFloat(-0xff); // returns -255
parseFloat("-0xFF"); // returns 0

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

parseFloat("44.jpg"); // return 44

parseFloat: 转换十六进制数时要当心,若是你不知道要转换对象的类型,不要使用 parseFloat。code

按位非

能够把字符串转换成整数,但他不是浮点数。若是是一个字符串转换,它将返回 0;对象

~~1.23; // returns 1
~~"1.23"; // returns 1
~~"23"; // returns 23
~~"Hello world"; // returns 0

这是什么原理?经过翻转每一个位,也称为数字的 A1 补码。你可使用它,但注意只能用来存储整数。因此一般状况不要用它,除非你能肯定这个数是在 32 位整数之间的值(由于调用的 ToInt32 的规范)。

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

Number

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

Number("023"); // returns 23
Number(023); // returns 19

注意:023 其实是一个八进制数,不管你怎么作,都是返回 19;对于没有单引号或双引号的十六进制数同样。

Number 也是 JsPerf 中最慢的之一。

Number:几乎不用它。

一元云算符

"1.23" * 1; // returns 1.23
"0xFF" - 0; // returns 255
"0xFF.jpg" / 1 + // returns NaN
    "023"; // returns 23

一元运算符与其它的解析方式不一样,若是是一个 NaN 值,那么返回的也是 NaN 。这是我最喜欢的数值转换方式,由于我认为任何带有字符的对象都不该该被视为 0 或者根据他有多少位来“猜”。我基本使用 + 操做符,由于这个方式不容易混淆。虽然 -0 的用法也很好,但它并无很好的表达转换为数字的本意。

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

负十六进制数字符串转换为数字时。应首先将任何其转换为 String(例如经过 + "" ),而后使用一元运算符或带基数的 parseInt 解析为数字。可是结果不是 NaN 的数值时,使用 parseFloat 更为合适。

关于Fundebug

Fundebug专一于JavaScript、微信小程序、微信小游戏、支付宝小程序、React Native、Node.js和Java线上应用实时BUG监控。 自从2016年双十一正式上线,Fundebug累计处理了10亿+错误事件,付费客户有Google、360、金山软件、百姓网等众多品牌企业。欢迎你们免费试用

版权声明

转载时请注明做者Fundebug以及本文地址:

https://blog.fundebug.com/2018/07/07/string-to-number/

相关文章
相关标签/搜索