美文网首页
es6学习笔记整理(四)数值扩展

es6学习笔记整理(四)数值扩展

作者: 尤樊容 | 来源:发表于2018-02-09 13:51 被阅读13次
数值处理新增特征

1、新增方法
关于数学处理,比如立方根、指数
把原来全局的、处理数值相关的方法,都调整到number对象上,比如parseInt、parseFlout,但是行为不变,结果一样。

            //二进制以0b开头,b大小写都可以
            console.log(0b110110111010001);//输出十进制 28113
            //八进制0o开头,o大小写都可以 
            console.log(0o65423);//输出十进制 27411

Number.isFinite 判断该值是否有尽,是不是无穷

            console.log('12', Number.isFinite(12));//true
            console.log('NaN', Number.isFinite(NaN));//false
            console.log('1/0', Number.isFinite('true'/0));//false
            
            console.log('isNaN', Number.isNaN(NaN));//true
            console.log('0', Number.isNaN(0));//false

Number.isInteger 判断该值是否是整数, 接收的必须是数值

            
            console.log('12', Number.isInteger(12));//true
            console.log('12.0', Number.isInteger(12.0));//true
            console.log('12.1', Number.isInteger(12.1));//false
            console.log('122', Number.isInteger('122'));//false 接收的必须是数值

Number.isSafeInteger
判断该值是否在-2的53次方到2的53次方之间,超过这个范围,无法精确表示这个值。
*要保证传进来的参数是数值
*Number.MAX_SAFF_INTEGER 最大 2的53次方
*Number.MIN_SAFF_INTEGER 最小 -2的53次方

            console.log(Number.MAX_SAFE_INTEGER, Number.MIN_SAFE_INTEGER); //9007199254740991 -9007199254740991
            console.log('12', Number.isSafeInteger(12));//true
            console.log('a', Number.isSafeInteger('a'));//false ‘a’不是数
            console.log('9007199254740991', Number.isSafeInteger(9007199254740992));//false
            console.log('9007199254740992', 9007199254740992 === 9007199254740993);//true  这个数超出了精度范围,导致在计算机内部,以9007199254740992的形式储存。
        

Math.trunc 取数值的整数部分

            console.log('12.122', Math.trunc(12.122));//12
            console.log('12.922', Math.trunc(12.922));//12

Math.sign 判断该值是正数、负数还是0

            console.log('12', Math.sign(12));//1
            console.log('-12', Math.sign(-12));//-1
            console.log('0', Math.sign(0));//0
            console.log('123', Math.sign('123'));//1 将字符串转化为数字了
            console.log('abc', Math.sign('abc'));//NaN

Math.cbrt 立方根
*对于非数值,Math.cbrt方法内部也是先使用Number方法将其转为数值。

            console.log('8', Math.cbrt(8));//2
            console.log('-1', Math.cbrt(-1));//-1

还有很多类似的方法,这里就不一一列举了:
(1)Math.clz32方法返回一个数的32位无符号整数形式有多少个前导0。
(2)Math.imul方法返回两个数以32位带符号整数形式相乘的结果,返回的也是一个32位的带符号整数。
(3)Math.fround方法返回一个数的单精度浮点数形式。
(4)Math.hypot方法返回所有参数的平方和的平方根。
注意:如果参数不是数值,Math.hypot方法会将其转为数值。只要有一个参数无法转为数值,就会返回NaN。

对数方法,ES6新增了4个对数相关方法。

(1)Math.expm1(x)返回ex - 1,即Math.exp(x) - 1。
(2)Math.log1p(x)方法返回1 + x的自然对数,即Math.log(1 + x)。如果x小于-1,返回NaN。
(3)Math.log10(x)返回以10为底的x的对数。如果x小于0,则返回NaN。
(4)Math.log2(x)返回以2为底的x的对数。如果x小于0,则返回NaN。

三角函数方法, ES6新增了6个三角函数方法

(1)Math.sinh(x) 返回x的双曲正弦(hyperbolic sine)
(2)Math.cosh(x) 返回x的双曲余弦(hyperbolic cosine)
(3)Math.tanh(x) 返回x的双曲正切(hyperbolic tangent)
(4)Math.asinh(x) 返回x的反双曲正弦(inverse hyperbolic sine)
(5)Math.acosh(x) 返回x的反双曲余弦(inverse hyperbolic cosine)
(6)Math.atanh(x) 返回x的反双曲正切(inverse hyperbolic tangent)
感谢i七月

相关文章

  • es6学习笔记整理(四)数值扩展

    数值处理新增特征 1、新增方法关于数学处理,比如立方根、指数把原来全局的、处理数值相关的方法,都调整到number...

  • es6学习笔记之数值扩展

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

  • es6的数值,函数,字符串扩展

    一、es6的数值扩展 二、es6的函数扩展 代码效果:对象解构在函数中的应用 三、es6字符串扩展 常用方法 代码...

  • ES6数值扩展

    阮一峰大神的ES6数值篇已经写的很好很全,下边贴出链接,然后斗胆写一点自己学习的总结。阮一峰ES6数值扩展我准备从...

  • ES6 学习笔记(5) 数值的扩展

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

  • ES6学习笔记(六):数值的扩展

    数字判断和转换 数字验证Number.isFinite(xx) 可以使用Number.isFinite( )来进行...

  • ES6学习笔记五|数值的扩展

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

  • 2018-04-21

    ES6数组的扩展整理

  • ES6学习—数值的扩展

    1.二进制和八进制表示法 2.Number.isFinite(), Number.isNaN() Number.i...

  • ES6扩展归纳

    ES6扩展归纳 介绍ES6相比与ES5在原有对象上的扩展,包括字符串、正则、数值、函数、数组、对象等扩展,本文是阮...

网友评论

      本文标题:es6学习笔记整理(四)数值扩展

      本文链接:https://www.haomeiwen.com/subject/pcrttftx.html