首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >vue3 项目生产环境切换路由卡死问题 【vue bug】

vue3 项目生产环境切换路由卡死问题 【vue bug】

作者头像
星宇大前端
发布2021-02-02 16:34:51
发布2021-02-02 16:34:51
3.2K0
举报
文章被收录于专栏:大宇笔记大宇笔记

工作那么多年第一次遇到一个问题卡了两天,最后也不是自己解决的。感谢 edison1105大神帮忙解决问题,记录一下,以后还会有人踩坑。

背景


最近用vue3 全家桶写了 后端管理系统。 传送门

  • vue3 + compositionAPI
  • ts
  • vue-router

问题


开发很流程,在开发环境运行也很好,部署到服务器的时候报错。

代码语言:javascript
复制
[Deprecation] 'window.webkitStorageInfo' is deprecated. Please use 'navigator.webkitTemporaryStorage' or 'navigator.webkitPersistentStorage' instead.
代码语言:javascript
复制
Uncaught (in promise) DOMException: Failed to read the 'value' property from 'SVGLength': Could not resolve relative length.

分析


看来看去都找不去原因,查看堆栈信息。

首先我调用了router.push 方法,然后vue router 调用了 vue ,最后在traverse函数报错。

是在解决不了了,感觉像是vue bug 决定提了一个issue。

解决


edison1105大神加了微信,协助定位解决。

最后原因由于我 watch(useRoute()) 产生了问题,

错误代码:

代码语言:javascript
复制
watch(useRoute(), current => {

})

我watch 了整个route 对象,route 对象太大了,如果组件内部使用了 window 对象 在 deep watch 的时候 就会出现你遇到的错了

正确写法:

代码语言:javascript
复制
watch(()=>useRoute().xxx,xxx)

watch 想要监听的属性就行,无需整个route watch

我提出的issue ,大神有回复,可以看下。

总结:


1、感觉dev环境没有问题,生产环境出错,这种问题vue-router是不是也要背锅

2、自己写代码不仔细,有冗余部分,尽量减少冗余,减少出错。

3、定位问题能力有待加强。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021/01/28 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 背景
  • 问题
  • 分析
  • 解决
  • 总结:
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档