Vue3实战笔记(65)—记录本项目浪费不少时间求证的问题

文章目录


前言

笔记最重要的作用就是温故而知新,最近遇到不少问题都是曾经遇到的,知道就是想不起来,查查自己的笔记都轻松解决了,老怀甚慰,深刻的意识到及时记录问题的重要性,今天记录几个最近遇到的几个看似简单解决起来却比较耗时的问题。


一、多个根问题

1、多个router-view之间切换,我从子路由切换到其他的router-view,路由过去了,界面没反应。尝试了很多方案,甚至使用router-view命名方式,也没有解决。

解决方案:

最外层router-view 使用了过渡动画,导致的这个问题的原因是:

runtime-core.esm-bundler.js:39 Vue warn: Component inside renders non-element root node that cannot be animated.

javascript 复制代码
    <router-view  v-slot="{ Component }">
       <transition name="bounce" mode="out-in" >
          <component :is="Component" />
      </transition>
    </router-view>

这个问题很恶心,如果子组件有多个根节点上述写法就会报错,如果组件没有多个根还不报警告,为了不一一更改多个组件,改善一下,加个div

javascript 复制代码
  <router-view  v-slot="{ Component }">
       <transition name="bounce" mode="out-in" >
        <div >
          <component :is="Component" />
        </div>
      </transition>
    </router-view>

二、动画失效

上一个问题解决了,但是这样改有时候动画会失效,更恶心的还会出现动画弹出来了,内容没了。解决方案需要加个key,transition会根据是key的变化判断元素改变,

触发动画:

javascript 复制代码
 <router-view  v-slot="{ Component }">
       <transition name="bounce" mode="out-in" >
        <div :key="$route.path">
          <component :is="Component" />
        </div>
      </transition>
    </router-view>

三、首次加载动画效果不生效,不同router-view之间切换无动画效。

解决方案:增加首次加载动画生效属性appear

javascript 复制代码
 <router-view  v-slot="{ Component }">
       <transition name="bounce" mode="out-in" >
        <div :key="$route.path">
          <component :is="Component" appear />
        </div>
      </transition>
    </router-view>

总结

这几个问题看似简单却无迹可寻,网上和官网找不到很直接的答案,都是一步步断点,看源码,分析原理思考各种可能性,慢慢探索解决。学习技术不能不求甚解,拿来主义,复制过来或者看看文档的用法,很多问题是自己解决不掉的。一入动画深似海。。。这几个问题看似简单却无迹可寻,网上和官网找不到很直接的答案,都是一步步断点,看源码,分析原理思考各种可能性,慢慢探索解决。学习技术不能不求甚解,拿来主义,复制过来或者看看文档的用法,很多问题是自己解决不掉的。一入动画深似海。。。

不忧过往,不惧未来,把握今朝,心怀宇宙浩渺。不忧过往,不惧未来,把握今朝,心怀宇宙浩渺。

相关推荐
xuhaoyu_cpp_java7 小时前
项目学习(三)分页查询
java·经验分享·笔记·学习
原则猫9 小时前
HOOKS 背后机制
前端
码语智行9 小时前
首页导航跳转功能深度解析-系统内和系统外
前端
阿猫的故乡9 小时前
Vue过渡动画从入门到装X:淡入淡出、滑动、列表动画、第三方库全搞定
前端·javascript·vue.js
裕波10 小时前
Vue&ViteConf 2026 将于 7 月 18 日在上海举办,尤雨溪将现场发表主题演讲
vue.js·vite
IManiy10 小时前
总结之Vibe Coding前端骨架
前端
Cloud_Shy61810 小时前
解读《Effective Python 3rd Edition》:从练气到老魔(第五章 Item 33 - 35)
开发语言·人工智能·笔记·python·学习方法
JS菌10 小时前
AI Agent 沙箱双层防护体系:从权限过滤到内核隔离的完整实现
前端·人工智能·后端
做cv的小昊10 小时前
计算机图形学:【Games101】学习笔记08——光线追踪(辐射度量学、渲染方程与全局光照、蒙特卡洛积分与路径追踪)
图像处理·笔记·学习·计算机视觉·游戏引擎·图形渲染·概率论
星恒随风10 小时前
C++ 类和对象入门(五):初始化列表、explicit 和 static 成员详解
开发语言·c++·笔记·学习·状态模式