javascript新特性小技巧

2022-04-19  本文已影响0人  SailingBytes

1、?.与??

简化运算逻辑,如三木运算符、if

let data = {}

const msg = data ?. msg ?? 'message';   // message

?. 可以无限链下去,不论有多少属性,只要有最后可以访问到属性,就会直接赋值最后的属性值。否则当任何一个链出现问题,立刻停止,而后赋值undefined。

?? 出现null ,undefined值会后,合并默认值(??后面的值)。

具体详见js中?.、??、??=的用法

2、数字分隔符_

遇到数字足够大的时候,如果有个分隔符能按照规律隔开那就好了。

const num = 6000000000; // 无法轻易分辨

const num2 = 6_000_000_000; // 清晰明了

console.log(num2) // 6000000000

也可用于计算

const num1 = 1;

const num2 = 6_000_000_000;

const sum = num1 + num2; // 6000000001

3、BigInt数据类型,解决大数字

js数字大小受制于Number.MAX_SAFE_INTEGER。因为Javascript的数字存储使用了IEEE 754中规定的双精度浮点数数据类型,而这一数据类型能够安全存储 -(2^53 - 1) 到 2^53 - 1 之间的数值(包含边界值)。

Math.pow(2, 53) === Math.pow(2, 53) + 1 // true

这个是不对的,就是因为计算后的值超过了安全存储。故想处理大数字,需要借助与BigInt。

BigInt(Math.pow(2, 53)) === BigInt(Math.pow(2, 53) + 1); // true,错误

BigInt(Math.pow(2, 53)) === BigInt(Math.pow(2, 53) )+ BigInt(1); // false,正确

4、in 与 hasOwn

对象上是否存在某个属性。

hasOwnProperty 只能检测对象实例属性,无法检测原型中的属性

class Persion {

    constructor(name){

        this.name = name;

    }

    getName() {

        return name;

    }

}

var persion=new Persion(12,88);

console.log(persion.hasOwnProperty("xiaoming"));//true

console.log(persion.hasOwnProperty("getName"));//false

console.log("name" in persion);//true

console.log("getName" in persion);//true

但在Object.create这种情况下,hasOwnProperty会出现异常错误,而hasOwn则不会。

let object_one = Object.create(null);

Object.hasOwnProperty(object_one, 'age');  // Uncaught TypeError: Cannot convert object to primitive value

Object.hasOwn(object_one, 'age'); // false

"name" in object_one // false

上一篇 下一篇

猜你喜欢

热点阅读