ES6入门系列二(数值的扩展)

ES6 在 Number对象上新增了很多方法

1 .    Number.isFinite()判断是否为有限的数字

  和全局的isFinite() 方法的区别是

  isFinite('1') === true    ;    Number.isFinite('1') === false

  全局的isFinite()先调用Number() 方法  把  变量 转化为数字再进行判断, 所以返回 true,

  Number.isFinite()只能判断数字, 对于非数字一律返回false

 

2  ,  Number.isNaN() 判断是否为NAN,

  只有NaN 才返回true, 否则返回false

 

3 , ES6 把全局的parseInt()和parseFloat()   移植到了Number对象上,但行为保持不变,

 是为了逐步减少全局方法, 使语言逐渐模块化

 

4  , Number.isInterger()判断是否为整数,  注意一点,javascript内部整数和浮点数是同样的存储方法  

    所以Number.isInteger(2) === Number.isInteger(2.0) 

 

5,  Number.EPSILON是一个极小常量, 一般来说, 差值小于这个极小常量的两个数我们就认为是相等的

  因为JavaScript浮点数的计算不精确,0.1+ 0.2 = 0.30000000000000004

  如果 Math.abs(0.1+ 0.2 - 0.3)  < Number.EPSILON 我们就认为 0.1+ 0.2 =  0.3

 

6 ,  Number.isSafeInteger()  

  我们知道JavaScript表示整数的精度范围在-2的53次方到2的53次方之间,

  超过这个范围的整数JavaScript就无法精确表示了,比如

  Math.pow(2, 53) + 1 ===  Math.pow(2 ,53)    / true

  ES6引入了两个数来表示这个范围

  Number.MAX_SAFE_INTEGER = Math.pow(2, 53)  - 1;

  Number.MIN_SAFE_INTEGER = Math.pow(2, 53)  + 1;

  判断一个整数是否落在这个区域就可以用 Number.isSafeInteger()  ,

  它只能传整数进去, 不是整数一律返回false

  

7 , 基于6 我们知道JavaScript无法准确的表示大于2的53次方的整数, 

  由此ES6新增了一个bigint的数据类型, 数值后面加n 来区分数字

  typeof 1234n  ===  'bigint'

  当计算Math.pow(2, 53) + 1 的时候 

  9007199254740992 + 1 = 9007199254740992 (不精确)

  9007199254740992n + 1n = 9007199254740993n  (精确)

  在调用toString() 方法返回结果

  

  

转载于:https://www.cnblogs.com/LHLVS/p/10920069.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值