ES6操作符使用总结

最近做新项目时候用到了ES6 添加的一些运算符,使用起来很方便,简化了代码,增强了代码容错性。使用感不错,下面做了总结,本文也会持续维护。

1. !!props.useDefaultColor

这个技巧的作用是将任何 JavaScript 值转换为相应的布尔值。当原始值为假值(例如 false、null、undefined、空字符串 ''、数字 0、NaN)时,结果为 false;当原始值为真值时,结果为 true。

2. 可选链运算符 ?.

  • 可选链运算符(?.)允许读取位于连接对象链深处的属性的值,而不必明确验证链中的每个引用是否有效。
  • ?. 运算符的功能类似于 . 链式运算符,不同之处在于,在左侧的对象为空 (null 或者 undefined) 的情况下不会引起错误,返回 undefined
  • 可选链可以帮助我们减少判断有效值的代码,特别是深层嵌套对象下访问某个属性,如果属性不存在,不会引起错误。
  • 另外,可以在使用可选链时设置一个默认值,和下面的Null 判断运算符 ?? 搭配使用:
javascript 复制代码
let useInfo = {
  name: "铁锤妹妹",
  details: { age: 18 }
}
let add = useInfo ?.city ?? '默认值'; // 同等于使用 useInfo ?.city || '默认值'
console.log(add) // '默认值'
  • 链判断运算符?. 有三种写法

1)obj?.prop // 对象属性是否存在

2)obj?.[expr] // 同上

3)func?.(...args) // 函数或对象方法是否存在

使用案例:

javascript 复制代码
const firstName = message?.body?.user?.firstName || 'default';

3. Null 判断运算符 ??

javascript 复制代码
context.$attrs.renderValue ?? '-'
  • 上面代码中,默认值只有在左侧属性值为nullundefined时,才会生效。
  • 可以简化代码并提高可读性,特别是在需要提供默认值的情况下。
  • 上面案例表示如果 context.$attrs.renderValue 不为 null 或 undefined,则返回 context.$attrs.renderValue 的值;否则,返回 '-'。这个表达式的作用是提供一个默认值,以防止 context.$attrs.renderValue 为 null 或 undefined 时引发错误或产生意外结果。
  • 这个运算符的一个目的,就是跟链判断运算符?.配合使用,为nullundefined的值设置默认值。
javascript 复制代码
const animationDuration = response.settings?.animationDuration ?? 300;
  • 上面代码中,如果response.settingsnullundefined,或者response.settings.animationDurationnullundefined,就会返回默认值300。也就是说,这一行代码包括了两级属性的判断。
  • ??本质上是逻辑运算,它与其他两个逻辑运算符 && 和 || 有一个优先级问题,如果多个逻辑运算符一起使用,必须用括号表明优先级,否则会报错。
javascript 复制代码
lhs && middle ?? rhs  // 报错

(lhs && middle) ?? rhs;
lhs && (middle ?? rhs);

使用案例

javascript 复制代码
// 通过计算属性将addReferFee,baseReferFee 值为null或undefined时,默认返回0,然后将两个值进行相加
const totalAmount = computed(()=>{
    const addReferFee = state.baseInfo?.addReferFee ?? 0
    const baseReferFee = state.baseInfo?.baseReferFee ?? 0
    return calulateAdd(addReferFee, baseReferFee )
})
function calulateAdd(num1:Decimal.Value, num2:Decimal.Value){
    return Decimal.add(num1,num2).toNumber()
}

4. ! 是 非空断言操作符

javascript 复制代码
 item!.roleUid === row!.roleUId
  • item!.roleUid:表示从 item 对象中获取 roleUid 属性的值。! 是 TypeScript 中的非空断言操作符,它告诉 TypeScript 编译器,item 对象一定不是 null 或 undefined,可以安全地访问其属性。
  • row!.roleUId:类似地,表示从 row 对象中获取 roleUId 属性的值,同样使用了非空断言操作符。
  • 注意,非空断言操作符 ! 的使用要小心,它会告诉 TypeScript 编译器"我很确定这个值不会是 nullundefined",因此如果实际上出现了 null 或 undefined 的情况,会导致运行时错误。因此,在使用非空断言操作符时,需要确保对象确实不会为 nullundefined

更详细的请阅读:ES6官方文档 - 运算符的扩展

相关推荐
独泪了无痕1 小时前
使用Fetch API 探索前后端数据交互
前端·http·交互设计
css趣多多1 小时前
别名路径的知识点
前端
靓仔建3 小时前
Vue3导入组件出错does not provide an export named ‘user_setting‘ (at index.vue:180:10)
开发语言·前端·typescript
EnoYao3 小时前
我写了一个团队体检报告 Skill,把摸鱼的同事扒出来了😅
前端·javascript
梁正雄3 小时前
Python前端-2-css练习
前端·css·python
清汤饺子3 小时前
用 Cursor 半年了,效率还是没提升?是因为你没用对这 7 个功能
前端·后端·cursor
Never_Satisfied3 小时前
在JavaScript / Node.js中,package.json文件中的依赖项自动选择最新版安装
javascript·node.js·json
蓝莓味的口香糖3 小时前
【vue3】组件的批量全局注册
前端·javascript·vue.js
wefly20174 小时前
开发者效率神器!jsontop.cn一站式工具集,覆盖开发全流程高频需求
前端·后端·python·django·flask·前端开发工具·后端开发工具
独泪了无痕4 小时前
自动导入 AutoImport:告别手动引入依赖,优化Vue3开发体验
前端·vue.js·typescript