解决Vue根组件设置transition失效的问题

解决Vue根组件设置transition失效的问题

1.代码

html 复制代码
<div id="app">
   <!-- :name="$route.meta.transitionName" -->
   <transition :name="'animation'" mode="out-in">
     <router-view  />
   </transition>
 </div>
 <!-- 动画部分代码省略 -->

这样直接设置会发现路由切换时并没有效果,但是你每次修改代码后保存刷新页面时却又能看到一次动画效果。

2.解决办法

在router-view标签设置 key属性,并且确保是唯一的,这里我设置 :key="$route.fullPath"

以下为修改后的代码:

html 复制代码
<div id="app">
   <!-- :name="$route.meta.transitionName" -->
   <transition :name="'animation'" mode="out-in">
     <router-view :key="$route.fullPath" />
   </transition>
 </div>

修改后,transition动画就正常了。

分析

在 <router-view> 上使用 :key="route.fullPath" 时,每当路由发生变化时,route.fullPath 的值会发生变化,因为它会随着新的路由而更新。
这就意味着,每当路由切换时, 组件的 key 会变化,从而触发 Vue.js 重新渲染组件。
在重新渲染的过程中,过渡效果会应用于离开的旧组件和进入的新组件,从而实现平滑的过渡效果。

相关推荐
0x0001 分钟前
Uniapp - 自定义 Tabbar 实现
前端·uni-app
用户458203153173 分钟前
Flexbox布局上手:10分钟告别垂直居中难题
前端·css
牛蛙点点申请出战5 分钟前
仿微信语音 WaveView 实现
android·前端·ios
yiyesushu6 分钟前
react + next.js + ethers v6 项目实例
前端
明远湖之鱼7 分钟前
巧用 Puppeteer + Cheerio:批量生成高质量 Emoji 图片
前端·爬虫·node.js
落笔忆梦9 分钟前
利用浏览器空闲时间优化资源加载与渲染
前端·javascript
我是日安9 分钟前
Day 2 - 开发环境建置:monorepo
vue.js
艾小码10 分钟前
还在用Vue 2硬撑?升级Vue 3的避坑指南来了!
前端·javascript·vue.js
是晓晓吖10 分钟前
page.waitForResponse 执行环境:页面还是 Node.js?
前端·puppeteer
三十_11 分钟前
【Docker】学习 Docker 的过程中,我是这样把镜像越做越小的
前端·后端·docker