二进制和八进制表示法

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

0b111110111 === 503 // true;0o767 === 503; // true

es5开始,严格模式中,八进制不容许应用前缀0 示意,否则会报错

// 严格模式       (function(){         console.log(0o11 === 011); // 报错       })()
    // 非严格模式      (function(){          console.log(0o11 === 011); // true        })()

如果要将0b0o前缀的字符串数值转十进制,应用Number即可

Number('0o111')  // 7Number('0o10')  // 8


数值分隔符

较长的数值容许增加分隔符,es2021容许js的数值应用下划线(_)作为分隔符

let num = 1_000_000_000console.log(1000000000 === num);   // true

留神:分隔符并不影响原始值

分隔符没有距离位数的限度

let num2 = 1_00_0000_00console.log(100000000 === num2);  // true

小数和迷信计数法也能够应用数值分隔符

console.log(0.00_01); // 0.0001console.log(1e10_000); // Infinity

须要留神的是
1、_不能放在数值的最后面或最初面
2、_ 不能两个或以上的分隔符连在一起应用
3、_ 小数点的前后不能有分隔符
4、_ 迷信计数法中,示意指数的Ee前后不能有分隔符

// 全副报错3_.1413._1411_e121e_12123__456_14643011464301_

其它进制的数值也能够应用分隔符

console.log(0b1010_0001_1000_0101);  // 二进制console.log(0xA0_B0_C0);  // 十六进制

留神:进制的前缀前后不能应用分隔符: 0b、0B、0o、0O、0x、0X
不反对数值分隔符的函数:
1、Number()
2、parseInt()
3、parseFloat()

Number('123_456');  // NaNparseInt('123_456');  // 123


Number.isFinite(), Number.isNaN()

Number.isFinite():用来查看一个数值是否为无限的,即不是Infinity
无限:true
非无限或非数值:false

Number.isFinite(10);  // trueNumber.isFinite(1.2);  // trueNumber.isFinite(NaN);  // falseNumber.isFinite(Infinity);  // falseNumber.isFinite('东方不败');  // falseNumber.isFinite('123');  // falseNumber.isFinite(true);  // false

Number.isNaN() : 用来查看一个值是否为NaN,如果参数不是NaN,返回false

Number.isNaN(NaN);  // trueNumber.isNaN(10);  // falseNumber.isNaN('10');  // falseNumber.isNaN(true);  // falseNumber.isNaN(9/NaN);  // trueNumber.isNaN('东方不败' * 10);  // trueNumber.isNaN(true / true);  // true

留神
它们与传统的全局办法isFinite()isNaN()的区别在于,
传统办法先调用Number()将非数值的值转为数值,再进行判断,而这两个新办法只对数值无效。
Number.isFinite()对于非数值一律返回false
Number.isNaN()只有对于NaN才返回true,非NaN一律返回false


Number.parseInt(),Number.parseFloat()

ES5 : parseInt()parseFloat()
ES6 : Number.parseInt()Number.parseFloat()
行为齐全保持一致,这样做的目标是逐渐缩小全局性办法,使语言逐渐模块化

parseInt('12.55');  // 12Number.parseInt('12.55');   // 12parseFloat('12.55');  // 12.55Number.parseFloat('12.55');   // 12.55


isInteger()

Number.isInteger()用来判断值是否为整数

Number.isInteger(15);  // trueNumber.isInteger(15.1);  // false

如果值不是数值则返回false

Number.isInteger('15');  //falseNumber.isInteger(true);  //falseNumber.isInteger(NaN);  //falseNumber.isInteger();  //false
JavaScript 采纳 IEEE 754 规范,数值存储为64位双精度格局,数值精度最多能够达到 53 个二进制位(1 个暗藏位与 52 个无效位),如果数值的精度超过这个限度,第54位及前面的位就会被抛弃,这种状况下,Number.isInteger可能会误判。
Number.isInteger(3.0000000000000002) // true

下面代码中,Number.isInteger的参数明明不是整数,然而会返回true,起因就是这个小数的精度达到了小数点后16个十进制位,转成二进制位超过了53个二进制位,导致最初的那个2被抛弃了。
==!!!!! 总之,如果对数据精度的要求较高,不倡议应用Number.isInteger()判断一个数值是否为整数。==


Math对象的扩大

Math.trunc()

Math.trunc用于去掉数值的小数局部,返回整数局部

Math.trunc(5.1);  // 5Math.trunc(5.5);  // 5Math.trunc(-5.1); // -5Math.trunc(-0.123);  // 0

对于非数值,会先应用Number办法将其转换为数值再返回

Math.trunc(true); // 1Math.trunc(false); // 0Math.trunc(null); // 0Math.trunc('10.123'); // 10

对于空值或无奈转换的值,返回NaN

Math.trunc(NaN);  // NaNMath.trunc('hello');  // NaNMath.trunc();  // NaN

Math.sign()

Math.sign()办法用来判断一个数到底是负数、正数、还是零。非数值会先转换为数值

阐明后果
参数为负数+1
参数为正数-1
参数未00
参数为-0-0
其余NaN
Math.sign('5');  // 1Math.sign(5); // 1Math.sign(-5); // -1Math.sign(0); // 0Math.sign(-0); // -0Math.sign(true); // 1Math.sign('hello'); // NaN

Math.hypot()

Math.hypot()办法返回所有参数的平方和和平方根

Math.hypot(3,4);  // 5Math.hypot(3,4,5); // 7.0710678118654755Math.hypot(3,4,'5'); // 7.0710678118654755Math.hypot(3,4,'hello'); // NaNMath.hypot(); // 0


重点 !

BigInt 数据类型

js的所有数字都保留成64位浮点数,这给数值的示意带来了很大的限度
一 :数值的经度只能到53个二进制位,相当于16个十进制位,大于这个范畴的负数无奈准确示意,使得js不适宜进行迷信和金融方面的准确计算。
二 :大于等于21024次方的数值,js无奈示意,会返回Infinity

// 超过53个二进制的数值们无奈放弃精度Math.pow(2,53) === Math.pow(2,53) + 1;  // true
// 超过2的1024次方的数值,无奈示意Math.pow(2,1024);  // Infinity

对此,ES2020引入了新的数据类型BigInt(大整数),作为第八种数据类型,BigInt只用来示意整数,没有位数限度,任何位数的整数都能够准确示意,语法: 数据n

// 应用BigInt  let a = 2172141653n  let b = 15346349309n  console.log(a*b);  // 33334444555566667777n  // 能够放弃精度
// 一般数值  let c = 2172141653  let d = 15346349309  console.log(c * d);  // 33334444555566670000 // 无奈放弃精度

与整数的区别

  • 123 一般整数
  • 123n BigInt
  • BigInt 类型的数据必须增加后缀n

BigInt与一般整数是两种值,它们之间并不相等

15n === 15; // false


数据类型返回bigint

typeof(15n); // bigint

BigInt函数

BigInt能够用来做数据转换,转换的办法与Number()基本一致

BigInt(123);  // 123nBigInt('123'); // 123nBigInt(true); // 1nBigInt(false); //0n

上面是报错的一些场景

BigInt();   //  TypeErrorBigInt('hello');   //  SyntaxError/* 字符串 123n 会无奈解析成Number类型,所以报错 */BigInt('123n');   //  SyntaxErrorBigInt(null);   //  TypeErrorBigInt(NaN);   //  TypeError/* 参数是小数也会报错 */BigInt(1.2);   //  RangeErrorBigInt('1.2');   //  SyntaxError

BigInt继承了Object对象的两个实例办法

  • BigInt.prototype.toString()
  • BigInt.prototype.valueOf()


它还继承了 Number 对象的一个实例办法

  • BigInt.prototype.toLocaleString()


此外还提供了三个静态方法

  • BigInt.asUintN(width, BigInt)
  • BigInt.asIntN(width, BigInt)
  • BigInt.parseInt(string[, radix])

BigInt 转换规则

能够应用BooleanNumberString 这三个办法,将BigInt转换为布尔、数值、字符串类型,转换后,后缀n会隐没

Boolean(0n);  // falseNumber(2n);  // 2String(2n);  // '2'

取反 ! 运算符能够转换布尔值

console.log( !0n );  // trueconsole.log( !1n );  // false

BigInt 数学运算

在数学运算方面, + - ***这四个运算符与number类型基本一致,除法运算 / 会舍去小数局部,返回一个整数

 console.log( 9 / 5 );  // 1.8 console.log( 9n / 5n );  // 1n  舍去小数

简直所有的数值运算符都能够用在 BigInt,然而有两个例外

  • 不带符号的右移位运算符>>>
  • 一元的求正运算符+


BigInt不能与一般数值混合运算,因为这样精度会失落

console.log( 2n + 5);  // TypeError

同样的起因,如果一个函数参数预期是Number类型,然而失去的是一个BigInt就会报错。

// 谬误的写法Math.sqrt(4n) // 报错// 正确的写法Math.sqrt(Number(4n)) // 2

BigInt其余运算

BigInt对应的布尔值,与Number类型统一

  • 0n : false
  • 1n : true
let n = 1nif(n){   console.log(true);} else {   console.log(false);}  // true

比拟运算符和相等运算符容许BigInt与其余类型的值混合计算,因为这样做不会损失精度。

 console.log( 0n < 1 );  // true console.log( 0n == false);  // true console.log( 0n == 0);  // true console.log( 0n === 0);  // false


案例源码:https://gitee.com/wang_fan_w/es6-science-institute

如果感觉这篇文章对你有帮忙,欢送点亮一下star哟