html将字符串转换为数字,如何将js中字符串转化为数字?js将字符串转化为数字的5种用法总结...

在js中将字符串转化为数字的方式有很多种,但是选择哪一种方法最为合适呢?在这里我将介绍五种把字符串转化为数字的方法,并且每种方法都来分析一下。

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

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

parseFloat(num) // 浮点数

Number(num); // Number 构造器

~~num //按位非

num / 1 // 除一个数

num * 1 // 乘一个数

num - 0 // 减去0

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

js中parseInt用法:

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

parseInt('44.jpg') // returns 44

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

js中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。

js中按位非:

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

~~"1.23" // returns 1

~~"23" // returns 23

~~"Hello world" // returns 0

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

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

js中Number的用法:

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

Number(023) // returns 19

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

Number也是JsPerf中最慢的之一。

Number:几乎不用它。

js中一元运算符的用法:"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更为合适。

相关推荐:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值