解决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 重新渲染组件。
在重新渲染的过程中,过渡效果会应用于离开的旧组件和进入的新组件,从而实现平滑的过渡效果。

相关推荐
fishmemory7sec4 分钟前
Electron 主进程与渲染进程、预加载preload.js
前端·javascript·electron
fishmemory7sec7 分钟前
Electron 使⽤ electron-builder 打包应用
前端·javascript·electron
工业互联网专业37 分钟前
毕业设计选题:基于ssm+vue+uniapp的校园水电费管理小程序
vue.js·小程序·uni-app·毕业设计·ssm·源码·课程设计
豆豆1 小时前
为什么用PageAdmin CMS建设网站?
服务器·开发语言·前端·php·软件构建
计算机学姐1 小时前
基于SpringBoot+Vue的在线投票系统
java·vue.js·spring boot·后端·学习·intellij-idea·mybatis
JUNAI_Strive_ving1 小时前
番茄小说逆向爬取
javascript·python
看到请催我学习1 小时前
如何实现两个标签页之间的通信
javascript·css·typescript·node.js·html5
twins35202 小时前
解决Vue应用中遇到路由刷新后出现 404 错误
前端·javascript·vue.js
qiyi.sky2 小时前
JavaWeb——Vue组件库Element(3/6):常见组件:Dialog对话框、Form表单(介绍、使用、实际效果)
前端·javascript·vue.js
煸橙干儿~~2 小时前
分析JS Crash(进程崩溃)
java·前端·javascript