news 2026/4/15 7:36:15

Vue 开发踩坑:Cannot read properties of null

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Vue 开发踩坑:Cannot read properties of null

Vue 开发踩坑:Cannot read properties of null —— 从爆红到根治的 3 分钟急救手册


正文目录

  1. 报错含义:null 从何而来?
  2. 4 大高频翻车现场 & 修复代码
  3. 万能兜底工具:可选链与默认值
  4. 预防 checklist(不再踩坑)
  5. 一句话总结

一、报错含义:null 从何而来?

当你在控制台看到:

Cannot read properties of null (reading 'xxx')

Vue 在告诉你:
「你试图读取null.xxx,但 null 没有属性。」
在 Vue 中,99% 是「异步数据 / 初始状态 / DOM 未挂载」三选一。


二、4 大高频翻车现场 & 修复代码

① 异步数据初始为 null

<script setup> const user = ref(null); // 初始 null onMounted(async () => { user.value = await fetchUser(); // 异步回来 }); </script> <template> <p>{{ user.name }}</p> <!-- ❌ 首屏 null --> </template>

修复:初始空对象 + 可选链

constuser=ref({});// 或 { name: '' }// 模板<p>{{user?.name??'加载中...'}}</p>

② 嵌套链式访问中途 null

<template> <p>{{ article.author.bio }}</p> <!-- ❌ author 为 null --> </template>

修复:可选链一路到底

<p>{{ article?.author?.bio ?? '暂无简介' }}</p>

③ DOM 未挂载就操作 ref

<script setup> const canvas = ref(null); // 初始 null onMounted(() => { canvas.value.getContext('2d'); // ✅ 这里安全 }); // ❌ 提前调用 canvas.value.getContext('2d'); // 报错

修复:只在生命周期后使用

onMounted(()=>{canvas.value?.getContext('2d');// 可选链保险});

④ 数组/对象解构空值

const{name}=user.value;// ❌ user.value 为 null

修复:默认值解构

const{name='Guest'}=user.value??{};

三、万能兜底工具:可选链与默认值

场景工具示例
模板可选链?.{{ obj?.a?.b ?? '' }}
JS 逻辑空合并??const val = obj ?? {}
深路径lodash getget(obj, 'a.b.c', '')
响应式新增Vue.setVue.set(obj, 'newProp', val)

四、预防 checklist

  • 异步数据初始化为空对象/数组而非null
  • 模板层统一用?.+??兜底
  • 生命周期内再操作 DOM / 异步数据
  • 解构时给默认值const { a = '' } = obj ?? {}
  • 大数据路径用lodash/get或可选链

五、一句话总结

「Cannot read properties of null」= 对象/数组/DOM 还没准备好就被读取。
用「可选链 + 默认值 + 生命周期」三件套,让 null 永远挡在读取之前,报错瞬间消失!


最后问候亲爱的朋友们,并邀请你们阅读我的全新著作

📚 《Vue.js 3企业级项目开发实战(微课视频版》

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/15 0:01:24

JetBrains Maple Mono终极指南:如何快速配置完美的编程字体体验

JetBrains Maple Mono终极指南&#xff1a;如何快速配置完美的编程字体体验 【免费下载链接】Fusion-JetBrainsMapleMono JetBrains Maple Mono: The free and open-source font fused with JetBrains Mono & Maple Mono 项目地址: https://gitcode.com/gh_mirrors/fu/Fu…

作者头像 李华
网站建设 2026/4/13 8:15:23

nanomsg高性能通信:构建下一代分布式系统的核心技术

nanomsg高性能通信&#xff1a;构建下一代分布式系统的核心技术 【免费下载链接】nanomsg nanomsg library 项目地址: https://gitcode.com/gh_mirrors/na/nanomsg nanomsg是一个革命性的高性能消息传递库&#xff0c;专门为构建可扩展的分布式系统而设计。作为传统消息…

作者头像 李华
网站建设 2026/4/9 3:38:13

ANSYS Fluent UDF高级编程完整手册:深度扩展仿真定制功能

ANSYS Fluent UDF高级编程完整手册&#xff1a;深度扩展仿真定制功能 【免费下载链接】ANSYSFluentUDFManual2020R2官方手册资源下载 本开源项目提供了ANSYS Fluent UDF Manual (2020R2) 的官方PDF文件下载&#xff0c;专为希望在Fluent中进行自定义编程的用户设计。手册详细介…

作者头像 李华
网站建设 2026/4/12 22:57:22

前端开发人员:以下是如何充分利用 Cursor

前端开发人员&#xff1a;如何充分利用 Cursor Cursor 是一个基于 VS Code 的 AI 驱动代码编辑器&#xff0c;专为开发者设计&#xff0c;尤其适合前端工作。它集成了大型语言模型&#xff08;如 Claude 或 GPT&#xff09;&#xff0c;能帮助你快速生成、调试和优化代码。作为…

作者头像 李华
网站建设 2026/4/5 3:31:33

[C语言]双向循环链表的增删改查功能

[C语言]双向循环链表的增删改查功能 1. 前言 本例提供一个可复用的双向循环链表模板&#xff0c;含完整接口与菜单式示例主程序&#xff0c;便于快速集成或学习链表操作。 2. 功能/亮点概览 双向循环 哨兵节点&#xff0c;边界处理简单。增删改查全覆盖&#xff0c;含头/尾…

作者头像 李华
网站建设 2026/4/11 1:44:05

鸣潮玩家必看:5大自动化功能让游戏效率提升300%

鸣潮玩家必看&#xff1a;5大自动化功能让游戏效率提升300% 【免费下载链接】ok-wuthering-waves 鸣潮 后台自动战斗 自动刷声骸上锁合成 自动肉鸽 Automation for Wuthering Waves 项目地址: https://gitcode.com/GitHub_Trending/ok/ok-wuthering-waves 还在为重复的刷…

作者头像 李华