Vue.js前端框架教程13:Vue空值合并?? 可选链?.和展开运算符...

文章目录

        • ??(空值合并运算符)
        • [| - 逻辑或(Logical OR)](#| - 逻辑或(Logical OR))
        • [|| - 空值合并运算符(Nullish Coalescing Operator)](#|| - 空值合并运算符(Nullish Coalescing Operator))
        • [?. - 可选链(Optional Chaining)](#?. - 可选链(Optional Chaining))
        • [... 展开运算符(Spread Operator)](#... 展开运算符(Spread Operator))
??(空值合并运算符)

??ES2020 新增的空值合并运算符,它只在左侧的操作数为 nullundefined 时才返回右侧操作数的值。如果左侧操作数不是空值,无论其值是 0falseNaN''(空字符串)还是其他假值,都会返回左侧操作数的值。

javascript 复制代码
const a = null;
const b = 'default';

console.log(a ?? b); // 输出 'default'
console.log(0 ?? b); // 输出 0,因为 0 不是 null 或 undefined
console.log(a ?? null ?? b); // 输出 'default',因为第一个操作数是 null,第二个操作数也是 null
console.log('text' ?? b); // 输出 'text',因为 'text' 不是 null 或 undefined
区别
  • || 会在左侧操作数为假值(包括 nullundefined0falseNaN'')时返回右侧操作数的值。
  • ?? 仅在左侧操作数为 nullundefined 时返回右侧操作数的值,对其他假值会返回左侧操作数的值。

因此,|| 更适合用于布尔逻辑和条件运算,而 ?? 更适合用于提供一个默认值,特别是当你想要保留原始值中的假值时。

| - 逻辑或(Logical OR)

JavaScript 中,| 是逻辑或运算符,用于两个布尔值的比较。如果其中一个值为 true,则结果为 true

javascript 复制代码
true | false // true
false | false // false

Vue 模板中,你可以使用它来实现条件渲染:

html 复制代码
<template>
  <div v-if="condition1 | condition2">
    <!-- 如果 condition1 或 condition2 为 true,这个元素将被渲染 -->
  </div>
</template>
|| - 空值合并运算符(Nullish Coalescing Operator)

||JavaScript 中用于逻辑或,但它的行为与 | 略有不同。如果左侧的表达式为 nullundefined,则 || 会返回右侧的值。

javascript 复制代码
undefined || 'default' // 'default'
'value' || 'default' // 'value'

Vue 中,这可以用于提供默认值:

vue 复制代码
<template>
  <div>{{ value || 'default' }}</div>
</template>
?. - 可选链(Optional Chaining)

?.JavaScript 的一个新特性,允许你安全地访问对象的深层属性,即使中间有 nullundefined 的值也不会抛出错误。

javascript 复制代码
const obj = { a: { b: 'value' } };
const value = obj?.a?.b; // 'value'

Vue 中,这可以用于安全地访问响应式数据:

vue 复制代码
<template>
  <div>{{ obj?.a?.b }}</div>
</template>
... 展开运算符(Spread Operator)

..JavaScript 的展开运算符,用于将数组或对象中的元素展开。

javascript 复制代码
const array = [1, 2, 3];
const newArray = [...array, 4, 5]; // [1, 2, 3, 4, 5]

Vue 中,这可以用于 v-bindv-on 指令:

html 复制代码
<template>
  <div v-bind="$attrs"></div>
</template>

这些符号和特性在 Vue 中的使用与在纯 JavaScript 中的使用是一致的,它们提供了更灵活和强大的数据处理能力。

相关推荐
wuicer1 小时前
ubuntu 20.04 安装anaconda以及安装spyder
linux·运维·ubuntu
加班是不可能的,除非双倍日工资1 小时前
css预编译器实现星空背景图
前端·css·vue3
wyiyiyi2 小时前
【Web后端】Django、flask及其场景——以构建系统原型为例
前端·数据库·后端·python·django·flask
gnip2 小时前
vite和webpack打包结构控制
前端·javascript
excel2 小时前
在二维 Canvas 中模拟三角形绕 X、Y 轴旋转
前端
cui__OaO3 小时前
Linux软件编程--线程
linux·开发语言·线程·互斥锁·死锁·信号量·嵌入式学习
小狗爱吃黄桃罐头3 小时前
正点原子【第四期】Linux之驱动开发篇学习笔记-1.1 Linux驱动开发与裸机开发的区别
linux·驱动开发·学习
阿华的代码王国3 小时前
【Android】RecyclerView复用CheckBox的异常状态
android·xml·java·前端·后端
一条上岸小咸鱼3 小时前
Kotlin 基本数据类型(三):Booleans、Characters
android·前端·kotlin
Jimmy3 小时前
AI 代理是什么,其有助于我们实现更智能编程
前端·后端·ai编程