记录一次关于Nuxt3报TypeError: Cannot read properties of null (reading 'parentNode')

版本描述:

nuxt:v3.7.4

vue:v3.3.4

node:v18.16.0

pnpm: v8.6.2

问题描述

当网速较慢的用户在新页面获取内容之前多次点击NuxtLink时,就会报错,dom直接渲染不出来,网站无响应卡素死,需要刷新才能恢复功能,报错如下图

复现问题

打开控制台->network->网络切换成slow 3G->点击其他页面跳转,在没有渲染出页面之前,请立刻多次点击这个页面的link,就会报错。

解决问题

报错的提示是渲染的时候parentNode不存在,分析得知大概率是vue的问题。

通过nuxt上面这个issuegithub.com/nuxt/nuxt/i...有了解决思路。 这个问题其实跟nuxt的版本没有太大关系,就算升级到最新的nuxt版本也没有用, 所以也尝试了直接升级vue到最新的3.3.10版本,遗憾的是问题没有解决。

接着通过点击报错的文件进去看到parentNode: (node) => node.parentNode,发现这个没有做判空处理,通过issue里面的一些大佬的描述,最后是给 @vue/runtime-dom 这个包patch,刚好pnpm>=v7.11.0 有patch功能,这里需要注意一下,pnpm的版本。

话不多说,来上重点吧

bash 复制代码
pnpm patch @vue/runtime-dom
  • 在项目控制台执行这段代码会生成如下的提示
  • 在本地找到上面提示的文件夹->打开dist文件夹->在runtime-dom.esm-bundler.js进行修改
  • 在文件内找到这段代码做个判空处理

parentNode: (node) => node.parentNode 替换成 parentNode: (node) => node ? node.parentNode : null

  • 修改保存后在项目控制台运行下面代码

pnpm patch-commit C:\Users\31303\AppData\Local\Temp\43845abc39a6abbd54a

  • 如果在项目里看到这些信息就表明补丁添加成功

后面项目组同学在pnpm i的时候也会进行安装,另外在node_modules里面的@vue/runtime-dom对应文件也可以看到相应的内容被修改了

这里有个地方需要注意的是,安装包的时候用pnpm,运行build的时候也一定要用pnpm,否则会有你预想不到的问题

按照如上的步骤,依次进行,问题顺利解决,如果比较着急的同学可以先这么处理,不着急的同学还是等Vue官方在某个版本解决吧。

遇到问题并不可怕,重要的是解决问题的能力,欢迎大家留言,一起共同进步

相关推荐
tedcloud1234 小时前
UI-TARS-desktop部署教程:构建AI桌面自动化系统
服务器·前端·人工智能·ui·自动化·github
UXbot7 小时前
AI原型设计工具如何支持团队协作与快速迭代
前端·交互·个人开发·ai编程·原型模式
ZC跨境爬虫8 小时前
跟着MDN学HTML_day_48:(Node接口)
前端·javascript·ui·html·音视频
PieroPc10 小时前
CAMWATCH — 局域网摄像头监控系统 Fastapi + html
前端·python·html·fastapi·监控
巴巴博一11 小时前
2026 最新:Trae / Cursor 一键接入 taste-skill 完整教程(让 AI 前端告别“AI 味”)
前端·ai·ai编程
kyriewen11 小时前
半夜三点线上崩了,AI替我背了锅——用AI排错,五分钟定位三年老bug
前端·javascript·ai编程
kyriewen11 小时前
我让 AI 当了 24 小时全年无休的“毒舌考官”
前端·ci/cd·ai编程
hexu_blog11 小时前
vue+java实现图片批量压缩
java·前端·vue.js
IT_陈寒12 小时前
为什么你应该学习JavaScript?
前端·人工智能·后端
lifejump12 小时前
Empire(帝国)CMS 7.5 XSS注入
前端·安全·xss