当前位置: 首页 > news >正文

取个对象值导致系统崩溃

取个对象值导致系统崩溃

前言

想必各位小伙经常在项目中遇到一些错误,取对象值的时候,经常报错,又或者某些项目突然就经常都是出现在一些对象取值上面,然后就被领导一顿训斥

image-20230812094958371

报错分析

例如: 下面这个报错大家想必不会陌生,就是读取不存在对象的变量

Uncaught TypeError: Cannot read properties of undefined (reading 'b')

那么为什么我们会遇到这个问题呢?

下面复现以下场景

假设: 服务端给我们返回一个列表数据,如下

[{title: '新闻信息1',info: {content: '新闻内容1',createTime: '2023-8-12 09:54:42'}},{title: '新闻信息2',info: {content: '新闻内容2',createTime: '2023-8-12 09:54:42'}},{title: '新闻信息3',info: {content: '新闻内容3',createTime: '2023-8-12 09:54:42'}}
]

那么前端循环就是这样

<ul><li class="li" v-for="(item, index) in list" :key="index"><div class="title">{{ item.title }}</div><div class="content">{{ item.info.content }}</div></li>
</ul>

目前看是不是没有问题,但是正常情况下也是不会报错

此时我们修改一下,list里的某个数据, 例如: 某个info为 null 或者 undefined

{title: '新闻信息3',info: null
}

那么此时我们就收到报错

image-20230812095912157

这个报错很容易定位,也容易修改,但是要是在线上出现这样子的问题,就是系统崩溃

那么我们应该用什么办法避免这种问题?

解决方案

目前来看这种对象里取属性的场景,在代码开发过程中是很常见的,那么我们写代码有哪几种快捷的方式?来处理这种问题?

第一种 通过 && 判断对象是否存在,在读取值

{{ item.info && item.info.content }} // 先判断 item.info 是否存在  存在则读取content否则不是读取

第二种 v-if 与 第一种方法类似

<div class="content" v-if="item.info">{{ item.info.content }}</div> // 通过v-if判断在info存在再渲染元素

第三种 ?. 可选链运算符 当引用的对象为null或者undefined不会引起报错,返回undefined

第三种也是我最推荐一种,代码量最少,最便捷

<div class="content">{{ item.info?.content }}</div>

目前我能想到的方法就这几种,不知道还有没有更好方式

总结

虽然这种错误不一定是前端的问题,但是代码的健壮性还是很重要的,个人目前也业务中就经常遇到这样子的问题,服务端返回的某些对象在没有值的情况下就是null,所以导致前端代码报错。

总结

虽然这种错误不一定是前端的问题,但是代码的健壮性还是很重要的,个人目前也业务中就经常遇到这样子的问题,服务端返回的某些对象在没有值的情况下就是null,所以导致前端代码报错。

都是血的教训,希望大家少遇到这样子的错误

http://www.lryc.cn/news/124956.html

相关文章:

  • nestjs 基础、使用 passport 来进行鉴权
  • 1.1 : DNA 螺旋
  • .gitignore匹配规则
  • Python-OpenCV中的图像处理-GrabCut算法交互式前景提取
  • JAVA 鼠标控制与键盘输入控制
  • VB+SQL宿舍管理系统设计与实现
  • 自律人生:戒断视频、游戏、小说、躺在床上不玩手机、睡觉前总结和冥想(提升注意力、专注度)
  • 学习笔记十四:K8S最小调度单元POD概述
  • ARM--day2(cpsr、spsr、数据搬移指令、移位操作指令、位运算操作指令、算数运算指令、比较指令、跳转指令)
  • idea报错:java: 程序包org.springframework.web.bind.annotation不存在
  • Android平台GB28181设备接入端如何实现多视频通道接入?
  • Evaluation Warning: The document was created with Spire.Doc for JAVA.
  • Java“牵手”根据关键词搜索(分类搜索)京东商品列表页面数据获取方法,京东API实现批量商品数据抓取示例
  • AIGC|AGI究竟是什么?为什么大家都在争先入场?
  • 【数学建模】--主成分分析
  • gitee(码云)如何生成并添加公钥,以及配置用户信息
  • wangeditor上传图片并展示在输入框内方法(vue3)
  • UGUI基础游戏对象Canvas
  • PK Nounique CASCADE DROP INDEX keep index
  • 【Antd】实现Table组件行点击,解决某一列不触发行点击
  • Kafka3.0.0版本——Broker( 退役旧节点)示例
  • 【Rust】Rust学习 第十二章一个 I/O 项目:构建一个命令行程序
  • 【MySQL--->表的操作】
  • PyTorch从零开始实现ResNet
  • 企业微信 企业内部开发 学习笔记
  • 03 QT基本控件和功能类
  • epoll数据结构
  • LINUX学习笔记_GIT操作命令
  • 第一百二十九天学习记录:数据结构与算法基础:栈和队列(中)(王卓教学视频)
  • C语言 — qsort 函数