一、进制

  ES6不仅完善了数字的八进制形式,还补充了一种十六进制形式,并且添加了全新的二进制形式。下面的三个变量分别表示八进制、十六进制和二进制的10,注释中给出了该进制的另一种写法。

var octal = 0o12,      //或0O12
hex = 0xa,  //或0XA
binary = 0b1010; //或0B1010

  注意,只有十进制才能表示小数。

二、Number

  ES6不仅增强了Number对象处理数字的精度,还扩展了它的数字运算能力,新增的属性和方法如表2所示。

表2  Number的属性和方法

属性或方法 功能描述
EPSILON 一个常量,表示1和大于1的最小值之间的差值:2^-52
MAX_SAFE_INTEGER 一个常量,表示JavaScript的安全整数的上限值:2^53 - 1
MIN_SAFE_INTEGER 一个常量,表示JavaScript的安全整数的下限值:-(2^53 - 1)
isFinite() 判断一个数字是否是有限的,如果参数是NaN、Infinity、-Infinity或非数字,都将返回false
isNaN() 判断一个值是否是NaN,只有当参数是NaN时,才能返回true
isInteger() 判断一个数字是否为整数,注意,12和12.0都被视为整数
isSafeInteger() 判断一个数字是否为安全整数

  表中的安全整数是指处在MIN_SAFE_INTEGER和MAX_SAFE_INTEGER之间的整数。

  在全局对象中有两个全局函数也叫isFinite()和isNaN(),但它们会先将传入的参数转换成数字,再进行判断,而Number对象中的新方法却不会执行这步类型转换,因此新方法能得到更为准确的结果。下面会分别对新方法和全局函数传入相同的参数,从它们的结果可知,新方法得到了期望值,而全局函数并没有。

Number.isFinite(null);   //false
isFinite(null); //true Number.isNaN("abc"); //false
isNaN("abc");    //true

三、Math

  ES6为Math对象新增了6个三角函数、4个对数方法,以及多个算术方法,具体如表3所示。

表3  Math的方法

方法 功能描述
sinh()和asinh() sinh()用于双曲正弦;asinh()用于反双曲正弦
cosh()和acosh() cosh()用于双曲余弦;acosh()用于反双曲余弦
tanh()和atanh() tanh()用于双曲正切;atanh()用于反双曲正切
expm1() 等价于Math.exp(x) - 1,可计算e^x - 1,其中x表示参数
log2() 返回以2为底的对数,如果参数小于0,则返回NaN
log10() 返回以10为底的对数,如果参数小于0,则返回NaN
log1p() 等价于Math.log(x+1),返回一个数字加1后的自然对数,如果参数小于-1,则返回NaN
hypot() 先将所有参数的平方相加,再计算和的平方根
cbrt() 计算数字的立方根
clz32() 先将数字转换成32位无符号整数形式的二进制,再计算前导0的个数
trunc() 只取数字的整数部分
imul() 让两个数字的32位整数相乘
fround() 将数字转换为离它最近的单精度浮点数形式的数字
sign() 返回数字的符号,指明数字是正数、负数还是零

  clz32()方法的描述比较抽象,现在用一个例子来讲解,先将10转换成32位的二进制,得到1010(省略了前面的28个0),再调用clz32()方法,最终的结果为28。

Math.clz32(10);        //

  sign()方法有5种返回值,分别是1、-1、0、-0和NaN,代表正数、负数、正零、负零和NaN,具体如下所示。

Math.sign(2);         //
Math.sign(-2); //-1
Math.sign(0); //
Math.sign(-0); //-0
Math.sign(NaN); //NaN

ES6躬行记(8)——数字的更多相关文章

  1. ES6躬行记(1)——let和const

    古语云:“纸上得来终觉浅,绝知此事要躬行”.的确,不管看了多少本书,如果自己不实践,那么就很难领会其中的精髓.自己研读过许多ES6相关的书籍和资料,平时工作中也会用到,但在用到时经常需要上搜索引擎中查 ...

  2. ES6躬行记 笔记

    ES6躬行记(18)--迭代器 要实现以下接口## next() ,return,throw 可以用for-of保证迭代对象的正确性 例如 var str = "向

  3. ES6躬行记(13)——类型化数组

    类型化数组(Typed Array)是一种处理二进制数据的特殊数组,它可像C语言那样直接操纵字节,不过得先用ArrayBuffer对象创建数组缓冲区(Array Buffer),再映射到指定格式的视图 ...

  4. ES6躬行记(4)——模板字面量

    模板字面量(Template Literal)是一种能够嵌入表达式的格式化字符串,有别于普通字符串,它使用反引号(`)包裹字符序列,而不是双引号或单引号.模板字面量包含特定形式的占位符(${expre ...

  5. ES6躬行记(21)——类的继承

    ES6的继承依然是基于原型的继承,但语法更为简洁清晰.通过一个extends关键字,就能描述两个类之间的继承关系(如下代码所示),在此关键字之前的Man是子类(即派生类),而在其之后的People是父 ...

  6. ES6躬行记(19)——生成器

    根据ES6制订的标准自定义迭代器实现起来比较复杂,因此ES6又引入了生成器的概念,生成器(Generator)是一个能直接创建并返回迭代器的特殊函数,可将其赋给可迭代对象的Symbol.iterato ...

  7. ES6躬行记(16)——Set

    ES6引入了两种新的数据结构:Set和Map.Set是一组值的集合,其中值不能重复:Map(也叫字典)是一组键值对的集合,其中键不能重复.Set和Map都由哈希表(Hash Table)实现,并可按添 ...

  8. ES6躬行记(12)——数组

    ES6为数组添加了多个新方法,既对它的功能进行了强化,也消除了容易产生歧义的语法. 一.静态方法 1)of() ES6为Array对象新增的第一个静态方法是of(),用于创建数组,它能接收任意个参数, ...

  9. ES6躬行记(3)——解构

    解构(destructuring)是一种赋值语法,可从数组中提取元素或从对象中提取属性,将其值赋给对应的变量或另一个对象的属性.解构地目的是简化提取数据的过程,增强代码的可读性.有两种解构语法,分别是 ...

随机推荐

  1. 《Linux就该这么学》第十一天课程

     防火墙常用的一些命令参数 原创地址:https://www.linuxprobe.com/chapter-08.html firewalld中常用的区域名称及策略规则 区域 默认规则策略 trust ...

  2. 学习Acegi应用到实际项目中(12)- Run-As认证服务

    有这样一些场合,系统用户必须以其他角色身份去操作某些资源.例如,用户A要访问资源B,而用户A拥有的角色为AUTH_USER,资源B访问的角色必须为AUTH_RUN_AS_DATE,那么此时就必须使用户 ...

  3. VMware虚拟机Linux增加磁盘空间的扩容操作

    转载自点击打开链接 用VMwareware虚拟机安装的Red Hat Enterprise Linux系统剩余空间不足,造成软件无法正常安装.如果重新装一遍系统就需要重新配置好开发环境和软件的安装配置 ...

  4. logback配置文件

    logback-spring.xml 通用配置文件如下: <?xml version="1.0" encoding="UTF-8"?> <co ...

  5. JSP 前端的一些应用

    Ext标签库 一.Ext.VeiwPort 代表整个浏览器显示区域,该对象渲染到页面的body 区域,并会随着浏览器显示区域的大小自动改变,一个页面中只能有一个ViewPort 实例. <scr ...

  6. vscode配置git及码云

    1.将代码放到码云 到码云里新建一个仓库,完成后码云会有一个命令教程按上面的来就行了 码云中的使用教程: Git 全局设置: git config --global user.name "A ...

  7. 安装virtualbox出现2503、2502的错误提示解决方法

    安装virtualbox右键选择以管理员的身份打开即可

  8. python计时器类

    import time as t class MyTimer(): def __init__(self): self.unit = ['年', '月', '日', '时', '分', '秒'] sel ...

  9. 图像处理及opencv汇总

    OPENCV——C++ 1.windows基于vs2017的opencv安装 2.为opencv添加contrib库 3.opencv源码编写规则 4.OpenCV库框架结构 5.OpenCV从2到3 ...

  10. vue的学习之路

    一.vs code中,适合vue的前端插件 查看网址:http://blog.csdn.net/caijunfen/article/details/78749766 二.如何使用git从gitub上拉 ...