JavaScript字符串转数字的5种方法及遇到的坑


Posted in Javascript onJuly 16, 2018

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的情况,应该检查转化后的值。

parseFloat('44.jpg') // return 44

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

按位非

可以把字符串转换成整数,但他不是浮点数。如果是一个字符串转换,它将返回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更为合适。

总结

以上所述是小编给大家介绍的JavaScript字符串转数字的5种方法及遇到的坑,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
jscript之Read an Excel Spreadsheet
Jun 13 Javascript
JavaScript的Cookies
Jan 16 Javascript
在浏览器中实现图片粘贴的jQuery插件-- pasteimg使用指南
Dec 29 Javascript
javascript函数式编程实例分析
Apr 25 Javascript
跟我学习javascript的闭包
Nov 16 Javascript
Fullpage.js固定导航栏-实现定位导航栏
Mar 17 Javascript
jquery实现网站列表切换效果的2种方法
Aug 12 Javascript
解决Layui 表单提交数据为空的问题
Aug 15 Javascript
vue click.stop阻止点击事件继续传播的方法
Sep 04 Javascript
Element实现表格分页数据选择+全选所有完善批量操作
Jun 07 Javascript
js实现鼠标拖拽div左右滑动
Jan 15 Javascript
vue flex 布局实现div均分自动换行的示例代码
Aug 05 Javascript
Angular-UI Bootstrap组件实现警报功能
Jul 16 #Javascript
JS在if中的强制类型转换方式
Jul 15 #Javascript
微信小程序form表单组件示例代码
Jul 15 #Javascript
微信小程序仿朋友圈发布动态功能
Jul 15 #Javascript
Bootstrap Table中的多选框删除功能
Jul 15 #Javascript
详解JavaScript 中 if / if...else...替换方式
Jul 15 #Javascript
简述JS控制台的使用
Jul 15 #Javascript
You might like
PHP 关于访问控制的和运算符优先级介绍
2013/07/08 PHP
PHP register_shutdown_function()函数的使用示例
2015/06/23 PHP
PHP创建/删除/复制文件夹、文件
2016/05/03 PHP
PHP页面间传递值和保持值的方法
2016/08/24 PHP
PHP屏蔽关键字实现方法
2016/11/17 PHP
PHP实现将多个文件压缩成zip格式并下载到本地的方法示例
2018/05/23 PHP
修改file按钮的默认样式实现代码
2013/04/23 Javascript
js中的数组Array定义与sort方法使用示例
2013/08/29 Javascript
PHP中使用微秒计算脚本执行时间例子
2014/11/19 Javascript
JS+DIV实现鼠标划过切换层效果的方法
2015/05/25 Javascript
学习javascript的闭包,原型,和匿名函数之旅
2015/10/18 Javascript
JavaScript SHA1加密算法实现详细代码
2016/10/06 Javascript
JavaScript中 this 指向问题深度解析
2017/02/21 Javascript
Angularjs中ng-repeat的简单实例
2017/08/25 Javascript
Nodejs异步回调之异常处理实例分析
2018/06/22 NodeJs
Vue2.2.0+新特性整理及注意事项
2018/08/22 Javascript
Vue.js轮播图走马灯代码实例(全)
2019/05/08 Javascript
vue学习笔记之slot插槽用法实例分析
2020/02/29 Javascript
python批量修改文件后缀示例代码分享
2013/12/24 Python
Python中使用gzip模块压缩文件的简单教程
2015/04/08 Python
Python的Flask框架中web表单的教程
2015/04/20 Python
Python出现segfault错误解决方法
2016/04/16 Python
django静态文件加载的方法
2018/05/20 Python
详解Python_shutil模块
2019/03/15 Python
python的debug实用工具 pdb详解
2019/07/12 Python
python list多级排序知识点总结
2019/10/23 Python
Python学习笔记之函数的参数和返回值的使用
2019/11/20 Python
四方通行旅游网:台湾订房、出国旅游
2017/09/20 全球购物
2014年寒假社会实践活动心得体会
2014/04/07 职场文书
加强作风建设演讲稿
2014/10/24 职场文书
门店店长岗位职责
2015/04/14 职场文书
奥巴马开学演讲观后感
2015/06/12 职场文书
无工作证明怎么写
2015/06/15 职场文书
提升Nginx性能的一些建议
2021/03/31 Servers
浅谈Golang 切片(slice)扩容机制的原理
2021/06/09 Golang
Java数据结构之链表相关知识总结
2021/06/18 Java/Android