当前位置: 首页 > news >正文

JS字符串转数字方法总结

String转换为Number有很多种方式,我可以想到的有5种!但总有一些情况让人猝不及防,总结到这里供自己日后查找方便

parseInt

根据JsPerf.com的基准测试,大多数浏览器对parseInt的响应最佳。虽然它是最快的方式,但使用preseInt会碰到一些常见陷阱:parseInt: 没有传入基数时,默认是传入的基数为10 parseInt(num, 10),如果你不知道num属性的类型,不要使用parseInt进行字符串转数字。

parseInt('043') // returns 0 部分老浏览器.
parseInt('20.mp4') // returns 20

parseFloat

如果你不解析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的规范)。 按位非:用它确保输入中没有字符,仅用于整数。

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

Number

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 的用法也很好,但它并没有很好的表达转换为数字的本意。

相关文章:

  • 经典算法详解(6)渔夫捕鱼
  • MariaDB 10.3 instant ADD COLUMN亿级大表毫秒级加字段
  • 09_用户行为分析_广告精准推送项目介绍
  • Linux 查看gpu信息 Nvidia显卡信息及使用情况
  • tensorflow笔记6:tf.nn.dynamic_rnn 和 bidirectional_dynamic_rnn:的输出,output和state,以及如何作为decoder 的输入...
  • CSS标签
  • 自我绘制四
  • 路飞学城-Python爬虫集训-第二章
  • 正则之从dom字符串中提取url
  • CSS面试复习(二):CSS的使用
  • ACM博弈
  • nginx File not found 错误
  • 微商代理系统APP软件
  • YAML基础语法
  • Spring深入理解(一)
  • 【跃迁之路】【444天】程序员高效学习方法论探索系列(实验阶段201-2018.04.25)...
  • Centos6.8 使用rpm安装mysql5.7
  • CoolViewPager:即刻刷新,自定义边缘效果颜色,双向自动循环,内置垂直切换效果,想要的都在这里...
  • CSS魔法堂:Absolute Positioning就这个样
  • iOS高仿微信项目、阴影圆角渐变色效果、卡片动画、波浪动画、路由框架等源码...
  • OSS Web直传 (文件图片)
  • overflow: hidden IE7无效
  • 从零到一:用Phaser.js写意地开发小游戏(Chapter 3 - 加载游戏资源)
  • 实现菜单下拉伸展折叠效果demo
  • 用Canvas画一棵二叉树
  • 最简单的无缝轮播
  • 《码出高效》学习笔记与书中错误记录
  • 《天龙八部3D》Unity技术方案揭秘
  • gunicorn工作原理
  • TPG领衔财团投资轻奢珠宝品牌APM Monaco
  • # 执行时间 统计mysql_一文说尽 MySQL 优化原理
  • #【QT 5 调试软件后,发布相关:软件生成exe文件 + 文件打包】
  • (附源码)spring boot儿童教育管理系统 毕业设计 281442
  • (附源码)spring boot基于小程序酒店疫情系统 毕业设计 091931
  • (四) 虚拟摄像头vivi体验
  • (转载)从 Java 代码到 Java 堆
  • ***详解账号泄露:全球约1亿用户已泄露
  • .NET 3.0 Framework已经被添加到WindowUpdate
  • .net经典笔试题
  • @data注解_SpringBoot 使用WebSocket打造在线聊天室(基于注解)
  • [ 数据结构 - C++] AVL树原理及实现
  • [Android]使用Android打包Unity工程
  • [BT]BUUCTF刷题第8天(3.26)
  • [bzoj1038][ZJOI2008]瞭望塔
  • [CareerCup] 12.3 Test Move Method in a Chess Game 测试象棋游戏中的移动方法
  • [cogs2652]秘术「天文密葬法」
  • [G-CS-MR.PS02] 機巧之形2: Ruler Circle
  • [HDU3710]Battle over Cities
  • [IE编程] IE8的SDK 下载
  • [JavaWeb]—Spring入门
  • [Quest ActiveRoles Management Shell for Active Directory] QADProxyAddress命令相关的bug。
  • [Spring MVC 4] MyBatis 分页开发
  • [SpringBoot] SpringBoot-04-读取yaml配置文件
  • [STL]C++ STL中常见容器的时间复杂度
  • [UE4]Animation Montage C++相关注意事项