二进制和八进制数值表示法

ES6提供了二进制和八进制数值的新写法,分别前缀 0b(或0B)、 0o(或0O)然后跟上二进制、八进制值即可。

  二进制(Binary)表示法新写法:前缀 0b 或 0B。

  let binary = 0b010101;        //
  let binary2 = 0B010111; //

  八进制(Octal)表示法新写法:前缀 0o 或 0O。

  let octal = 0o123;        //
  let octal2 = 0O1234;   //

  从ES5开始,严格模式下,八进制数值就不再允许用前缀0表示,ES6则进一步明确规定,八进制数值用0o前缀表示。

  // 非严格模式
  (function () {
  console.log(0o01 === 001);
  })();
  // true   // 严格模式
  (function () {
  'use strict';
  console.log(0o01 === 001); // Octal literals with prefix '0' are not allowed. Use '0o' prefix instead
  })();
  // Uncaught SyntaxError: Octal literals are not allowed in strict mode.

数值的验证、判断、以及转换

  ES6不仅提供了很多新的数值处理方法,同时还将之前相对零散的全局处理方法都整理到了Number对象里面。

  数值的验证:Number.isFinite()【用于检查一个数值是否为有限的( finite),即不是 Infinity】,Number.isNaN()【用于检查一个值是否为NaN】

  数值的判断:Number.isInteger()【用于判断一个数值是否为整数】,Number.isSafeInteger()【用于判断整数是否在安全整数范围内】

  数值的转换:Number.parseInt(),Number.parseFloat()

数值的验证:ES6在Number对象内,新提供了 Number.isFinite()和 Number.isNaN()两个方法。

  1、Number.isFinite():用于检查一个数值是否为有限的(finite),即不是Infinity。同时Number.isFinite() 没有进行隐式的 Number() 类型转换,所有非数值都返回 false。所以Number.isFinite()还可以用来进行数字验证,只要是数值,不论是整形还是浮点型都会返回 true,非数值则一律返回 false。

  console.log(Number.isFinite('testDemo'));        // false 字符串
  console.log(Number.isFinite(1992)); // true 整形数值
  console.log(Number.isFinite(0.5)); // true 浮点型
  console.log(Number.isFinite(true)); // false 布尔值
  console.log(Number.isFinite(null)); // false null
  console.log(Number.isFinite(undefined)); // false undefined
  console.log(Number.isFinite([1, 2, 3])); // false 数组
  console.log(Number.isFinite({test: 'Demo'})); // false 对象
  console.log(Number.isFinite(NaN)); // false NaN
  console.log(Number.isFinite(Infinity)); // false Infinity
  console.log(Number.isFinite(-Infinity)); // false -Infinity

  2、Number.isNaN():用于检查一个值是否为NaN。若参数类型不是NaN,Number.isNaN() 则一律返回 false而且 Number.isNaN() 也没有进行隐式的 Number() 类型转换。

  console.log(Number.isNaN('testDemo'));           // false
  console.log(Number.isNaN('testDemo'/0)); // true
  console.log(Number.isNaN('true'/'true')); // true
  console.log(Number.isNaN(1992)); // false
  console.log(Number.isNaN(1992/0)); // false
  console.log(Number.isNaN(0.5)); // false
  console.log(Number.isNaN(true)); // false
  console.log(Number.isNaN(true/0)); // false
  console.log(Number.isNaN(null)); // false
  console.log(Number.isNaN(undefined)); // false
  console.log(Number.isNaN([1, 2, 3])); // false
  console.log(Number.isNaN({test: 'Demo'})); // false
  console.log(Number.isNaN(NaN)); // true
  console.log(Number.isNaN(1992/NaN)); // true
  console.log(Number.isNaN(Infinity)); // false
  console.log(Number.isNaN(-Infinity)); // false

数值的判断:Number.isInteger()【用于判断一个数值是否为整数】,Number.isSafeInteger()【用于判断数值是否在安全范围内】

  1、Number.isInteger():用于判断一个数值是否为整数。如果参数不是数值,Number.isInteger()则返回false。

  console.log(Number.isInteger(0));                     // true
  // JavaScript内部,整数和浮点数采用同样的储存方法,因此 1 与 1.0 被视为相同的值
  console.log(Number.isInteger(1)); // true
  console.log(Number.isInteger(1.0)); // true   console.log(Number.isInteger(1.1)); // false
  console.log(Number.isInteger(Math.PI)); // false
  // NaN 和正负 Infinity 都不是整数
  console.log(Number.isInteger(NaN)); // false
  console.log(Number.isInteger(Infinity)); // false
  console.log(Number.isInteger(-Infinity)); // false   console.log(Number.isInteger("1992")); // false
  console.log(Number.isInteger(true)); // false
  console.log(Number.isInteger(false)); // false
  console.log(Number.isInteger(null)); // false
  console.log(Number.isInteger(undefined)); // false
  console.log(Number.isInteger([1,2,3])); // false
  console.log(Number.isInteger({test: 'Demo'})); // false   // 数值的精度超过53个二进制位(1个隐藏位,52个有效位)时,由于第54位及后面的位被丢弃,JS会产生误判,此时就相当于在判定1.000000000000000,所以会返回true。
  console.log(Number.isInteger(1.0000000000000001)); // true  
  // 同理,当一个数值的绝对值小于Number.MIN_VALUE(5E-324),即小于JavaScript能够分辨的最小值,会被自动转为0,此时JS也会产生误判。
  console.log(Number.isInteger(5E-324)); // false  5E-324 还没超出最小值范围,所以isInteger()判定还是false。
  console.log(Number.isInteger(5E-325)); // true   5E-325 由于值太小,超出JS能够分辨的最小值范围,所以被自动转为0,因此isInteger()判定为true。

  总之,如果对数据的精度要求较高,在进行数据是否为整数进行判定时,不建议使用Number.isInteger()方法。 

  2、Number.isSafeInteger():用于判定整数是否在安全整数范围内。

数值的转换:Number.parseInt(),Number.parseFloat()。ES6将之前的全局方法 parseInt() 和 parseFloat() 移植到了Number对象内,行为和之前的全局方法一样。这样将之前的全局方法逐步移植到各个模块内,既减少了全局性方法数量,又使得方法逐步模块化,聚合化。

  1、Number.parseInt():用于解析一个字符串,并返回一个整数。

  2、Number.parseFloat():用于解析一个字符串,并返回一个浮点数。

  // 不指定转换进制时,默认为 10 进制
  // parseInt() 和 Number.parseInt()
  // ES5写法
  parseInt('1992.102'); //
  parseInt(1992.102); //
  // ES6新写法
  Number.parseInt('1992.1020'); //
  Number.parseInt(1992.1020); //   // 指定转换进制时,第二个参数指定的基数(基数可以是10[默认基数,可以不写], 2, 8或 16等进制数),将字符串参数解析为有符号的整数。
  Number.parseInt('0101',2); //
  Number.parseInt('111',8); //
  Number.parseInt('222',16); //
  Number.parseInt('-333',10); // -333   // parseFloat() 和 Number.parseFloat()。两方法都是先判定指定字符串或数字串中的首个字符是否是数字。是,则对该字符串进行解析,直到数字的末端为止,然后以数字格式返回该数字。
  // 注:字符串中只返回第一个数字、字符串开头和结尾允许存在空格,但中间如出现空格,则空格后面的数字将不予识别。
  // ES5写法
  parseFloat('1992.1020abc'); // 1992.102
  parseFloat(1992.1020); // 1992.102
  parseFloat(' 199 2.1020abc '); //
  // ES6新写法
  Number.parseFloat('1992.1020abc'); // 1992.102
  Number.parseFloat(1992.1020); // 1992.102
  Number.parseFloat(' 1992.1 020abc '); // 1992.1   // 当首个字符无法被解析成整数和浮点数时(若首个字符被解析为正负号时,则判定第二个字符的解析结果),则都返回 NaN
  Number.parseInt('abc'); // NaN
  Number.parseFloat('abc'); // NaN   // Number.parseInt()与全局的 parseInt() 方法是同一个方法
  Number.parseInt === parseInt; // true
  // Number.parseFloat()与全局的 parseFloat() 方法也是同一个方法
  Number.parseFloat === parseFloat; // true

最大/最小安全数 以及Number.isSafeInteger()

  安全整数及安全整数范围:安全整数是 JavaScript 中能够精确表示的整数,其范围在 2 的 -53 次方到 2 的 53 次方之间(不包括两个端点,既(-Math.pow(2, 53),Math.pow(2, 53))),超过这个范围(不论是整数还是小数)JavaScript 都无法精确表示该数了。

  安全数范围:大小在 2 的 -53 次方到 2 的 53 次方之间(不包括两个端点,既(-Math.pow(2, 53),Math.pow(2, 53)))的数。

  最大安全整数:安全整数的上限,即 2 的 53 次方减 1 。  Math.pow(2, 53)-1;  // 9007199254740992-1

  最小安全整数:安全整数的下限,即 2 的 53 次方减 1 的负数。  -(Math.pow(2, 53)-1);  // -(9007199254740992-1)

  常量:ES6 引入了 Number.MAX_SAFE_INTEGER 和 Number.MIN_SAFE_INTEGER 两个常量,用来表示安全整数的上下限。以便于日常开发过程中 判定数值是否超出安全范围。

  Math.pow(2, 53);                                   //
  Math.pow(2, 53)-1; //
  -(Math.pow(2, 53)-1);   // -9007199254740991
  
  Math.pow(2, 53) === Math.pow(2, 53) + 0.01; // true,超出 2 的 53 次方之后,JS就无法精确表示这个值了,哪怕多0.01都不行。
  -Math.pow(2, 53) === (-Math.pow(2, 53))-0.01; // true   console.log(Number.MAX_SAFE_INTEGER);   //
  console.log(Number.MIN_SAFE_INTEGER);   // -9007199254740991   console.log(Number.MAX_SAFE_INTEGER === Math.pow(2, 53) - 1); // true
  console.log(Number.MIN_SAFE_INTEGER === -(Math.pow(2, 53) - 1)); // true

  Number.isSafeInteger():用于判定整数是否在安全整数范围内。

  // Number.isSafeInteger()用于判定整数是否在安全整数范围内
  Number.isSafeInteger(Number.MAX_SAFE_INTEGER); // true
  Number.isSafeInteger(Number.MAX_SAFE_INTEGER + 1); // false
  Number.isSafeInteger(Number.MIN_SAFE_INTEGER); // true
  Number.isSafeInteger(Number.MIN_SAFE_INTEGER - 1); // false
  Number.isSafeInteger(1992); // true

ES6 - 基础学习(5): 数值扩展的更多相关文章

  1. ES6 - 基础学习(6): 对象扩展

    对象对于JavaScript至关重要,在ES6中对象又加了很多新特性. 对象字面量:属性的简洁表示法 ES6允许对象的属性直接写变量,这时候属性名是变量名,属性值是变量值. let attr1 = & ...

  2. ES6学习之数值扩展

    二进制和八进制表示法(二进制用前缀0b(或0B)表示,八进制用前缀0o(或0O)表示) Number('0b111') Number('0o10') Number.isFinite()(判断一个值是否 ...

  3. ES6 - 基础学习(1): 开发环境搭建

    现在Chrome浏览器已经很好的支持ES6了,但有些低版本的浏览器或其他浏览器还是不支持ES6的语法,因此实际项目开发或上线过程中就需要把ES6的语法转变成ES5的语法.项目开发过程中 Webpack ...

  4. ES6 基础学习

    ECMAScript 6 标准入门 一.let和const let命令 let命令,用来声明变量.它的用法类似于var,但是所声明的变量,只在let命令所在的代码块内有效:是块级作用域,且let不允许 ...

  5. ES6 - 基础学习(3): 变量的解构赋值

    解构赋值概述 1.解构赋值是对赋值运算符的扩展. 2.它是一种针对数组或者对象进行模式匹配,然后对其中的变量进行赋值. 3.代码书写上显得简洁且易读,语义更加清晰明了:而且还方便获取复杂对象中的数据字 ...

  6. ES6 - 基础学习(2): 新的变量声明方式 let 与 const

    ES6)新增加了两个重要的 JavaScript 关键字:let 和 const.以前声明变量时只有一种方式:var,ES6对声明方式进行了扩展,现在可以有三种声明方式了. 1.var:variabl ...

  7. ES6 - 基础学习(8): Promise 对象

    概述 Promise是异步编程的一种解决方案,比传统的解决方案(多层嵌套回调.回调函数和事件)更强大也更合理.从语法上说,Promise是一个对象,从它可以获取异步操作的消息,Promise 还提供了 ...

  8. ES6 - 基础学习(4): 模板字符串和字符串新增方法

    模板字符串 模板字符串:我理解为将字符串格式化.模板化,将字符串加强处理,此处的模板有动词的意思. 字符串模板基本格式: `xxxxxx`(前后都用反引号[tab键上面按键]引起来).除了作为普通字符 ...

  9. ES6基础-ES6的扩展

    进行对字符串扩展,正则扩展,数值扩展,函数扩展,对象扩展,数组扩展. 开发环境准备: 编辑器(VS Code, Atom,Sublime)或者IDE(Webstorm) 浏览器最新的Chrome 字符 ...

随机推荐

  1. 部署Maven项目到tomcat报错:java.lang.ClassNotFoundException: org.springframework.web.context.ContextLoaderLi

    Maven项目下update maven后Eclipse报错:java.lang.ClassNotFoundException: ContextLoaderL     严重: Error config ...

  2. xlwings excel(四)

    前言 当年看<别怕,Excel VBA其实很简单>相见恨晚,看了第一版电子版之后,买了纸质版,然后将其送人.而后,发现出了第二版,买之收藏.之后,发现Python这一编程语言,简直是逆天, ...

  3. FluentData -Micro ORM with a fluent API that makes it simple to query a database

    Code samples Create and initialize a DbContextThe connection string on the DbContext class can be in ...

  4. Python脚本通过ftp协议移植文件

    需求 项目需要定时移植多个客户服务器的文件到公司服务器上,确保文件定时同步和生成监控日志 机制原理 1.客户和公司服务器同时安装vpn,绕过复杂的网关,linux下使用的OpenVPN 2.服务器定时 ...

  5. Python3基础之正则表达式

    正则表达式 在线测试工具 http://tool.chinaz.com/regex/ 同一个位置上可以出现的字符的范围. 字符组 : [字符组] 在同一个位置可能出现的各种字符组成了一个字符组,在正则 ...

  6. Fibonacci Nim(斐波那契尼姆)游戏

    游戏描述: Fibonacci Nim是Nim游戏的变种,其规则为两名玩家从一堆硬币中交替移除硬币,第一步中,不允许玩家拿走所有硬币,也不允许不取,并且在每次后续移动中,移除的硬币数量最多可以是上一次 ...

  7. .net core 认证与授权(二)

    前言 这篇紧接着一来写的,在第一篇中介绍了认证与授权,同时提出了这套机制其实就是模拟现实中的认证与授权. 同样这篇介绍在这套机制下,用户信息管理机制?这里就会问了,上一篇中认证和授权不是都ok了吗,怎 ...

  8. 如何把您现有的流程系统数据迁徙到驰骋BPM上?

    关键词:流程系统版本切换\ 驰骋BPM. 如何把您现有的流程系统数据迁徙到驰骋BPM上?这是一个大问题.在处理改问题之前,首先要了解驰骋bpm的数据库结构,驰骋bpm的特性在做计划. 驰骋BPM的流程 ...

  9. .NET Core WebAPI post参数传递时后端的接收方式

    .NET Core WebAPI post参数传递时后端的接收方式 实体类 dynamic动态类型 JObject参数 单值参数(字符串参数) A.前端Post请求代码 $.ajax({ url: & ...

  10. C# 多态和接口

    1多态可以有属性,接口只有方法 2关键字不同,多态有静态多态(abstract)和动态多态(virtual),静态多态不能new()出自己,动态多态可以;多态中可以有自己的方法可设置不需要子类重写,接 ...