?.的写法 后缀修饰符

概览:处理后端返回的数据data,写法:data?.name。解决vue框架编译出现的报错Cannot read property 'name' of undefined。出现问题的原因:这是因为我们试图访问对象中不在的 key 为 name 的属性,那么怎么解决呢?

若是当前对象不存在某个属性key,在vue中可以使用后缀修饰符,常用的是?和!。

代码举例:

javascript 复制代码
            const resData = res.data.data || []
            const params1 = reactive({
                shyx: resData?.age?.shyx,
                shzwh: resData?.age?.shzwh,
                whys: resData?.age?.whys,
            })
            const params2 = resData.area?.map((item) => {
                return {
                    name: item.name,
                    value: item.num
                }
            })
            const params3 = reactive({
                partymember: resData?.partyMember?.partymember,
                other: resData?.partyMember?.other,
            })

vue3中两种后缀运算符:

在Vue 3中,有两个后缀运算符:?!,分别表示可选属性和非空断言。

?可选属性:表示该属性是可选的,如果该属性不存在,不会引发错误。

!非空断言:表示该属性一定存在,如果该属性不存在,则会引发错误。

?后缀运算符:

示例代码:

javascript 复制代码
const message = { text: 'Hello World' }
const greeting = message.text?.toUpperCase() // greeting = 'HELLO WORLD'
const emptyMessage = {}
const emptyGreeting = emptyMessage.text?.toUpperCase() // emptyGreeting = undefined

结果分析:

在上面的代码中,当message对象存在text属性时,可以将text属性的值转换为大写字母。而当emptyMessage对象不存在text属性时,使用?.运算符访问text属性不会引发错误,返回值为undefined

!后缀运算符:

实例代码:

javascript 复制代码
const message = { text: 'Hello World' }
const greeting = message.text!.toUpperCase() // greeting = 'HELLO WORLD'
const emptyMessage = {}
const emptyGreeting = emptyMessage.text!.toUpperCase() // TypeError

结果分析:

在上面的代码中,当message对象存在text属性时,可以将text属性的值转换为大写字母。而当emptyMessage对象不存在text属性时,使用!运算符访问text属性会引发错误,因为该属性不存在。

相关推荐
恋猫de小郭14 分钟前
compose_skill 和 android skills,对 Android 项目提升巨大的专家 AI Skills
android·前端·flutter
J_liaty34 分钟前
Vue2 从入门到精通
前端·javascript·vue.js
INF_MAX37 分钟前
一些不错的页面设计(持续记录)
前端
乔江seven1 小时前
LlamaIndex 实现ReAct Agent
前端·python·react.js
私人珍藏库1 小时前
Edge v146.0.3856.97 内置篡改猴脚本
前端·edge
Thomas21431 小时前
chrome cdp 三种方案对比
前端·chrome
别叫我->学废了->lol在线等1 小时前
claudecode的agent定义
前端·chrome·github
用户806138166591 小时前
SDK(Software Development Kit,软件开发工具包)
前端
张元清1 小时前
在 React 中构建沉浸式 Web 应用:全屏、屏幕常亮与系统通知
前端·javascript·面试
王霸天1 小时前
💥大屏卡成 PPT?这 3 个性能优化招数亲测有效
前端·vue.js·数据可视化