es6 基础学习之?. ??之类的相关

ES6 和后续版本中的可选链(Optional Chaining)和空值合并(Nullish Coalescing)

可选链(Optional Chaining)?.

可选链运算符(?.)允许你在尝试访问对象的某个属性时不必明确验证该对象是否存在。如果该对象不存在,表达式会短路,返回 undefined

基本用法:

javascript 复制代码
const user = {
  name: 'John',
  address: {
    street: '123 Main St',
  },
};

// 普通方式
const street = user && user.address && user.address.street;

// 使用可选链
const streetWithOptionalChaining = user?.address?.street;

console.log(street); // 输出 "123 Main St"
console.log(streetWithOptionalChaining); // 输出 "123 Main St"

可选链也可以用于函数调用:

javascript 复制代码
const result = someObject?.someMethod?.();

如果 someMethod 存在并且是一个函数,那么它会被调用;否则,result 会被赋值为 undefined

空值合并(Nullish Coalescing)??

空值合并运算符(??)用于为变量设置默认值。当你希望仅在变量为 nullundefined 时使用默认值,而不是依赖于变量的所有假值(如 0''false 等),这个运算符会非常有用。

基本用法:

javascript 复制代码
const value = null;
const defaultValue = 'Default Value';

const result = value ?? defaultValue;
console.log(result); // 输出 "Default Value"

结合使用

这两个运算符经常会被结合使用,以便更简洁地处理嵌套属性和设置默认值。

javascript 复制代码
const user = {
  name: 'John',
  preferences: {
    theme: 'Dark',
  },
};

const theme = user?.preferences?.theme ?? 'Light';

console.log(theme); // 输出 "Dark"

在这个例子中,如果 userpreferencesnullundefined,则 theme 将被设置为默认值 'Light'

这些是 ES6 和后续版本中可选链和空值合并的基本用法。这两个运算符都提供了一种更简洁、更安全的方式来处理 nullundefined,从而让代码更加易读和可维护。希望这些信息能帮助你更好地理解和使用这些特性。

相关推荐
国家不保护废物11 分钟前
从刀耕火种到现代框架:DOM编程 vs Vue/React 进化史
前端·vue.js·react.js
阿琳a_27 分钟前
前端对WebSocket进行封装,并建立心跳监测
前端·javascript·vue.js·websocket
Am1nnn31 分钟前
【Pinia】Pinia和Vuex对比
前端·javascript·vue.js
我的心巴2 小时前
vue-print-nb 打印相关问题
前端·vue.js·elementui
coderYYY3 小时前
element树结构el-tree,默认选中当前setCurrentKey无效
前端·javascript·vue.js
程序员秘密基地4 小时前
基于vscode,idea,java,html,css,vue,echart,maven,springboot,mysql数据库,在线考试系统
java·vue.js·spring boot·spring·web app
程序员-小李4 小时前
VuePress完美整合Toast消息提示
前端·javascript·vue.js
萌萌哒草头将军15 小时前
🚀🚀🚀Prisma 发布无 Rust 引擎预览版,安装和使用更轻量;支持任何 ORM 连接引擎;支持自动备份...
前端·javascript·vue.js
ai产品老杨17 小时前
减少交通拥堵、提高效率、改善交通安全的智慧交通开源了。
前端·vue.js·算法·ecmascript·音视频
张老爷子19 小时前
记录uniapp开发安卓使用webRTC实现语音推送
vue.js