1. 二进制和八进制表示法
ES6提供了二进制和八进制的新写法,分别用前缀0b(或0B)和0o(或0o)表示。
- 将0b和0o前缀的字符串数值转为十进制,要使用Number方法。
Number('0b111'); //7
2. Number.isFinite(),Number.isNaN()
- Number.isFinite()用来检查一个数值是否为有限的(finite)
- Number.isNaN()用来检查一个值是否为NaN
注意:两个方法与传统的isFinite()和isNaN()方法区别在于,传统方法先调用Number()将非数值的值转为数值,再判断。这两个方法只对数值有效,非数值一律返回false。
3. Number.parseInt(),Number.parseFloat()
与传统方法行为完全保持不变。目的在于,逐步减少全局性方法,使得语言逐步模块化。
4. Number.isInteger()
判断一个值是否为整数。
注意:JavaScript内部,整数和浮点数储存方法相同,所以3和3.0被视为同一个值。
5. Number.EPSILON
ES6中新增的一个极小的常量。
Number.EPSILON = 2.220446049250313e-16;
- 目的在于,设置误差范围。当误差小于该值,则认为得到正确结果。
6. 安全整数和Number.isSafeInteger()
JavaScript能够准确表示的整数范围在-2^53
到2^53之间(不含两个端点),超过这个范围,无法精确表示这个值。
- ES6引入了Number.MAX_SAFE_INTEGER
和Number.MIN_SAFE_INTEGER这两个常量,用来表示这个范围的上下限 - Number.isSafeInteger()则是用来判断一个整数是否落在这个范围之内。
7. Math对象的扩展
Math.trunc()
该方法用于去除一个数的小数部分,返回整数部分。
对于非数值,先转成数值。
对于空置和无法截取整数的值,返回NaN.
Math.sign()
-
该方法用于判断一个数是正数、负数还是0.
- 正数,返回+1
- 负数,返回-1
- 0,返回0
- -0,返回-0
- 其他值,返回NaN
Math.cbrt()
该方法用于计算一个数的立方根。
对于非数值,先转为数值再计算。
Math.clz32()
该方法返回一个数的32位无符号整数形式有多少个前导0.
对于小数,只考虑整数部分。
对于空置或者其他类型的值,先转为数值,再计算。
Math.fround()
返回一个数的单精度浮点数形式
Math.hypot()
该方法返回所有参数的平方和的平方根
参数不是数值,先转为数值,有一个无法转为数值,就返回NaN
对数方法
-
Math.expm1()
- 返回e的x次方 - 1,即Math.exp(x) - 1
-
Math.log1p()
- 返回1+x的自然对数。即Math.log(1 + x)。如果x小于-1,返回NaN
-
Math.log10()
- 返回以10为底的x的对数,如果x<10,则返回NaN.
-
Math.log2()
- 返回以2为底的x的对数。x<0,则返回NaN.
三角函数方法
Math.sinh(x)返回x的双曲正弦(hyperbolic sine)
Math.cosh(x)返回x的双曲余弦(hyperbolic cosine)
Math.tanh(x)返回x的双曲正切(hyperbolic tangent)
Math.asinh(x)返回x的反双曲正弦(inverse hyperbolic sine)
Math.acosh(x)返回x的反双曲余弦(inverse hyperbolic cosine)
Math.atanh(x)返回x的反双曲正切(inverse hyperbolic tangent)
8. 指数运算符
- 指数运算符**
2 ** 2 //4
2 ** 3 //8
- 与等号结合,**=
let a = 2
a **= 2 //a = 4