?? 、 || 、&&=、||=、??=这些运算符你用对了吗?

在日常开发中,你是不是也常用||来给变量设置默认值?比如

js 复制代码
const title = props.title || '默认标题';

看起来好像没什么大问题,但是当title0,false或者""的时候,或者思考比较全面的同学可能会额外加上关于0false''的判断,但其实有更简单的方法,就是使用??

?? 和 || 的区别

运算符 规则
|| 如果左边是 null 或 undefined,返回右边
?? 如果左边是"假值"(false、0、''、null、undefined),返回右边

??运算符是ES2020 引入的,除了引入了??,自从ES2020以来,还引入了其他几个运算符

可选链?.

用于安全访问多层嵌套对象属性,避免手动判断每一级是否存在

js 复制代码
const city = user?.address?.city;
  • 如果 useruser.addressnull未定义,不会抛错,而是直接返回 undefined
  • 支持属性访问: obj?.prop
  • 支持数组规线访问: arr?.[0]
  • 支持函数调用: fn?.()

逻辑与赋值&&=

其实等价于x &&= yx = x && y

当值为 true 时才赋值

逻辑或赋值||=

等价于x ||= yx = x || y

当值为 false 时才赋值

空值合并赋值??=

等价于x ??= yx = x ?? y

保留 0/空字符/假值,当值为 null 或 undefined 时才赋值

js 复制代码
let username = null;
username ??= 'Guest'; // 结果: 'Guest'

我看还有一些人介绍!!运算符,其实这个不算新加入的,甚至不是一个整体的运算符,他一直存在,只不过是利用了!的特性,做的一种常用写法

相关推荐
喝拿铁写前端9 分钟前
一套面向 Web、H5、小程序与 Flutter 的多端一致性技术方案
前端·架构
yaaakaaang15 分钟前
(一)前端,如此简单!---下载Nginx
前端·nginx
牛奶20 分钟前
为什么全国人民都能秒开同一个视频?
前端·http·cdn
KongHen021 小时前
uniapp-x实现自定义tabbar
前端·javascript·uni-app·unix
数据潜水员1 小时前
三层统计最小力度的四种方法
javascript·vue.js
汪子熙1 小时前
TS2320 错误的本质、触发场景与在 Angular / RxJS 项目中的系统化应对
前端·javascript·angular.js
我命由我123451 小时前
React - BrowserRouter 与 HashRouter、push 模式与 replace 模式、编程式导航、withRouter
开发语言·前端·javascript·react.js·前端框架·html·ecmascript
Younglina1 小时前
用AI全自动生成连环画?我试了,效果惊艳!
前端·ai编程·claude
Devin_chen1 小时前
ES6 Class 渐进式详解
前端·javascript
小番茄夫斯基1 小时前
前端开发的过程中,需要mock 数据,但是走的原来的接口,要怎么做
前端·javascript