资讯专栏INFORMATION COLUMN

ECMAScript6 新特性——“数值的扩展”

Dean / 2940人阅读

摘要:二进制和八进制表示法提供了二进制和八进制数值的新的写法,分别用前缀或和或表示。用来检查是否为有穷以及是否为这两个新方法只对数值有效,非数值一律返回。引入了和这两个常量,用来表示这个范围的上下限。因为有精度限制,超过的次方的值无法精确表示。

1 二进制和八进制表示法

ES6提供了二进制和八进制数值的新的写法,分别用前缀0b(或0B)和0o(或0O)表示。

console.log(0b1001110010); //626
console.log(0o626); //406
2 Number.isFinite(),Number.isNaN()

ES5:

isFinite(),isNaN()

ES6:

Number.isFinite(),Number.isNaN()

用来检查是否为有穷以及是否为NaN;

console.log(Number.isFinite(Infinity)); //false
console.log(Number.isNaN(NaN)); //true

这两个新方法只对数值有效,非数值一律返回false。

3 Number.parseInt(),Number.parseFloat()

ES5:

parseInt(),parseFloat()

ES6:

Number.parseInt(),Number.parseFloat()

新方法移植到Number对象上,行为与ES5一致

console.log(Number.parseInt("123.21")); //123
console.log(Number.parseFloat("321.321hr")); //321.321
4 Number.isInterger()

因为浮点数和整数是同样的储存方法,所以.0将被理解为整数

5 Number.EPSILON

极小的常量

console.log(Number.EPSILON); //2.220446049250313e-16
console.log(Number.EPSILON.toFixed(16)); //0.0000000000000002

let result = 0.1 + 0.2;
console.log((result - 0.3) < Number.EPSILON.toFixed(16)); //True
6 安全整数和Number.isSafeInteger()

JavaScript能够准确表示的整数范围在-2^53到2^53之间(不含两个端点),超过这个范围,无法精确表示这个值。

ES6引入了Number.MAX_SAFE_INTEGERNumber.MIN_SAFE_INTEGER这两个常量,用来表示这个范围的上下限。

需要注意的是不要只验证运算结果,同时必须验证参与运算的每个值

console.log(Number.MAX_SAFE_INTEGER); //9007199254740991
console.log(Number.isSafeInteger(Number.MAX_SAFE_INTEGER + 1)); //false
7 Math 对象的扩展

Math.trunc()

Math.trunc方法用于去除一个数的小数部分,返回整数部分。

Math.trunc(4.1) // 4

Math.sign()

Math.sign方法用来判断一个数到底是正数、负数、还是零。

console.log(Math.sign(321)); //1
console.log(Math.sign(-321)); //-1
console.log(Math.sign(-0)); //-0
console.log(Math.sign(0)); //0

Math.cbrt()

Math.cbrt方法用于计算一个数的立方根。

console.log(Math.cbrt(8)); //2

Math.clz32()

JavaScript的整数使用32位二进制形式表示,Math.clz32方法返回一个数的32位无符号整数形式有多少个前导0。

Math.clz32(0b01000000000000000000000000000000) // 1
Math.clz32(0b00100000000000000000000000000000) // 2

需要注意的是对于小数,改方法只考虑整数部分

Math.imul()

Math.imul方法返回两个数以32位带符号整数形式相乘的结果,返回的也是一个32位的带符号整数。

因为JavaScript有精度限制,超过2的53次方的值无法精确表示。这就是说,对于那些很大的数的乘法,低位数值往往都是不精确的,Math.imul方法可以返回正确的低位数值。

Math.fround()

返回一个数的单精度浮点数形式。

Math.fround(1);     // 1
Math.fround(1.337); // 1.3370000123977661
Math.fround(1.5);   // 1.5
Math.fround(NaN);   // NaN

Math.hypot()

返回所有参数的平方和的平方根。

Math.hypot(3, 4, 5);     // 7.0710678118654755
Math.hypot();            // 0
Math.hypot(NaN);         // NaN
Math.hypot(3, 4, "foo"); // NaN

对数方法

Math.expm1()

返回Math.exp(x) - 1

Math.log1p()

返回Math.log(1 + x)

Math.log10()

以10为底的x的对数

Math.log2()

以2为底的x的对数

三角函数方法

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 指数运算符**

ES7 新增的指数运算符**

2 ** 2 //4
2 ** 3 //8

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/79108.html

相关文章

  • ECMAScript6 特性——“let和const命令”

    摘要:基本用法所声明的变量,只在命令所在的代码块内有效。在循环中适合使用不存在变量提升不像那样会发生变量提升现象暂时性死区只要块级作用域内存在命令,它所声明的变量就绑定这个区域,不再受外部的影响。块级作用域实际上为新增了块级作用域。 1 let 基本用法 所声明的变量,只在let命令所在的代码块内有效。 { let b = 100; console.log(b); //100...

    PascalXie 评论0 收藏0
  • ECMAScript6 特性——“正则扩展

    摘要:第二个参数指定修饰符,如果存在则使用指定的修饰符。属性表示是否设置了修饰符属性的属性返回正则表达式的正文的属性返回正则表达式的修饰符字符串必须转义,才能作为正则模式。 1 RegExp构造函数 ES6 允许RegExp构造函数接受正则表达式作为参数。第二个参数指定修饰符,如果存在则使用指定的修饰符。 var regexp = new RegExp(/xyz/i, ig); consol...

    Shisui 评论0 收藏0
  • ECMAScript6 特性——“变量解构赋值”

    摘要:数组的解构赋值允许按照一定模式,从数组和对象中提取值,对变量进行赋值,这被称为解构。如果变量名与属性名不一致,必须写成下面这样。 1 数组的解构赋值 ES6允许按照一定模式,从数组和对象中提取值,对变量进行赋值,这被称为解构(Destructuring)。 基本用法 { var [a,[b,c],d,,...f] = [1,[2,3],4,5,6,7]; console...

    Eric 评论0 收藏0
  • ECMAScript6 特性——“字符串扩展

    摘要:吉字符串的遍历器接口为字符串添加了遍历器接口,使得字符串可以被循环遍历。提供字符串实例的方法,用来将字符的不同表示方法统一为同样的形式,这称为正规化。返回布尔值,表示参数字符串是否在源字符串的头部。 1 字符串的Unicode表示法 ES6 只要将码点放入大括号,就能正确解读该字符; var x = u20bb7; document.write(x); //₻7 var x = u{2...

    BlackMass 评论0 收藏0
  • ECMAScript6 特性——“对象扩展

    摘要:属性的简洁表示法允许直接写入变量和函数作为对象的属性和方法。,中有返回一个数组,成员是参数对象自身的不含继承的所有可遍历属性的键名。对象的扩展运算符目前,有一个提案,将解构赋值扩展运算符引入对象。 1 属性的简洁表示法 ES6允许直接写入变量和函数作为对象的属性和方法。 写入属性 var name = value; var obj = { name }; console.log...

    Clect 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<