?.的用法

 使用场景:

undefined和null是两个比较特殊的数据类型,是不能用点操作符去访问属性的,否则将会报错。

  • 空值合并操作符??

使用 ?? 时用于提供默认值,只有当左侧表达式的结果为 null 或 undefined 时,才会返回右侧表达式的值。

// ??
    console.log(undefined ?? 2);  // 2
    console.log(null ?? 2);   // 2
    console.log(0 ?? 2);  // 0
    console.log("" ?? 2);   // ''
    console.log(true ?? 2);  // true
    console.log(false ?? 2);   // false
 
  • 空值合并赋值操作符??=

用于在左侧操作数为 null 或 undefined 时,将右侧表达式的值赋给左侧操作数。 

  • 可选链操作符 ?. 

?. 允许读取连接对象链深处的属性的值,而不必明确验证链中的每个引用是否有效。

?. 操作符的功能类似于. 链操作符,不同之处在于,在引用为空,即 null 或者 undefined 的情况时不会抛出异常,而是返回 undefined。

这个符号表示对象后面的属性可以是null或undefined。

来访问对象的属性和调用对象的方法。

  • 非空类型断言!. 

 !.  这是TypeScript的语法

!.  非空类型断言,表示确定某个标识符是有值的

这个符号表示对象后面的属性一定不是null或undefined。

  • 强制类型转换!!

用于将一个值转换为对应的布尔值(强制类型转换)

  • 逻辑非运算符!

逻辑非运算符,用于取反一个布尔值或将一个值转换为布尔类型并取反。

  • 或运算||

使用 || 时,A会先转化为布尔值判断,为true时返回A , false 返回B

// ||
    console.log(undefined || 2);   // 2
    console.log(null || 2);     // 2
    console.log(0 || 2);        // 2
    console.log("" || 2);     // 2
    console.log(true || 2);     // true
    console.log(false || 2);      // 2

3、 

你可能感兴趣的:(javascript,javascript)