IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> JavaScript 中的 空值合并运算符 和 ?.(可选链操作符) -> 正文阅读

[JavaScript知识库]JavaScript 中的 空值合并运算符 和 ?.(可选链操作符)

是什么

空值合并运算符( Nullish Coalescing Operator )是一个逻辑运算符,使用**??表示!主要作用是检查一个值是否是null**或者undefined,如果是则返回运算符后面的值,你可以把这个后面的值当作备胎!类似相亲,会判断你是不是穷逼,如果你是穷逼,则会毫不犹豫的选择备胎!

例如:X??YY

如果这里的X 不是null或者undefined,否则返回Y!

我们可以将**??**等价于 (a!==null and a!==undefined)? a : b

示例

const a = 0 ?? 1;

根据空值合并运算符的定义,这里a的是0。

const a = undefined ?? 1
const b = null ?? 1

这个例子中的a都是1。

与||的区别

逻辑或运算符的作用是当左边的值是假值是,返回右边的值!

假值包括下面几种

  • NaN
  • 0
  • " " 或 ’ ’
  • null
  • undefined
  • false

在??之前,我们给一个变量赋默认值,我们的做法是使用||

let variable = 形参 || 备用值;

然后使用||,会出现0这个可以作为有效值的,被忽略掉!

let count = 0;

let variable = count || 42;

这里variabl的值就会是42,但是我们明明想要的是0。而空值合并运算符则可以避免这种情况!!!

?? 与 ?.

两个??是空值合并运算。一个?加**.叫做可选链操作符。可选链操作符,允许我们读取对象深层**不存在的属性。

例如:我们有一个user对象,他有一个name属性。

let user{
    name :"张三"
}

当我们想访问user.age,这个不存在的属性是,并不会报错!

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-yDUo6SlH-1655776039227)(https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/1844edc509c845e9b27fa6dc9cd96143~tplv-k3u1fbpfcp-zoom-1.image)]

我们访问更深一层的user.age.newAge,就会直接报错!

image-20220602215310076

我们给user.age可选链操作符,你会发现他不报错了!

user.age?.newage

image-20220602215555706

当然可选连最适合应用场景应该是API调用的时候,假设我们user对象中,本来有一个getName()方法,但是某一天,这个方法被注释掉了!

image-20220602220338884

image-20220602220414787

碰撞

对于**??**来说,它可以识别null和undefined,而我们的可选链又可以讲错误转成undefined,那么这两者放在一起,是不是可以给深层不存在的属性赋值啦!

const user = {
     name: "张三"
};

console.log(user.age?.newage ?? 18);  
console.log(user.getName?.() ?? "默认名字"); 

image-20220602220630735

总结

  1. 空值合并运算符 在左侧null或为undefined时返回右侧值。

  2. 当你想用假值做默认值,空值合并运算符是首选!

  3. **???.**搭配起来很好用!

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-06-25 18:01:20  更:2022-06-25 18:03:09 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 10:53:19-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码