分享5种JS字符串转数字的方法


本文摘自PHP中文网,作者青灯夜游,侵删。

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

本文介绍一下JavaScript字符串转数字的5种方法及其陷阱,希望对大家有所帮助。

String 转换为 Number 有很多种方式,我可以想到的有 5 种!

1

2

3

4

5

6

7

8

9

parseInt(num); // 默认方式 (没有基数)

parseInt(num, 10); // 传入基数 (十位数)

parseFloat(num); // 浮点数

Number(num); // Number 构造器

~~num; //按位非

num / 1; // 除一个数

num * 1; // 乘一个数

num -0  // 减去0

+ num; // 一元运算符 "+"

选择哪一种呢?什么时候选择它?为什么选择这种它?我们逐一进行分析,并解析每种方式的常见陷阱。

parseInt

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

1

2

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

parseInt("44.jpg"); // returns 44

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

parseFloat

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

1

2

3

4

parseInt(-0xff); // returns -255

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

parseFloat(-0xff); // returns -255

parseFloat("-0xFF"); // returns 0

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

1

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

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

阅读剩余部分

相关阅读 >>

怎么获取json的key

js中20个常用字符串方法及使用方式(总结)

js遍历对象有几种方法

快速理解 javascript 的垃圾回收

js中闭包是什么

javascript中string方法有哪些

js如何给下拉框设置默认值?

vue 动态加载 vuex

js如何判断一个对象是否是数组(函数)

js读写cookie

更多相关阅读请进入《js》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...