@giszhc/vue-page-motion:Vue3 路由动画怎么做才“丝滑”?(附在线示例)

👉 Vue3 路由动画怎么做才"丝滑"?从原理到工程实现,一次讲透 @giszhc/vue-page-motion

很多 Vue 项目一到"页面切换动画",就开始变味:

要么是生硬闪切

要么是 transition 写一半就摆烂

要么 KeepAlive 一加直接乱套 😅

今天我们用一个真实工程组件 ------ @giszhc/vue-page-motion,把"页面切换动画"这件事彻底讲明白。


在线示例

我们提供了一个功能完整的在线演示页面,您可以直接在浏览器中体验所有功能:

🌐 立即体验: 点击访问在线演示


1. 问题背景(真实场景)

在一个后台系统 / GIS 平台 / 中后台管理系统里,你一定见过这种需求:

  • 页面切换要有左右滑动效果
  • 返回上一页要"反向动画"
  • 某些页面需要禁用动画(比如地图页)
  • 页面状态要保持(表单不能丢)

👉 结果就是:

Vue Router + Transition + KeepAlive = 经典三体问题 ☠️

稍微写错一点,就会出现:

  • 页面"闪一下"
  • 动画方向错乱
  • 缓存页面不更新
  • 路由切换卡顿

2. 核心问题(本质分析)

问题本质其实就三个:

❗ 1. 路由状态 ≠ UI状态

Vue Router 只负责跳转,不负责动画语义。

❗ 2. Transition 只认识"进入/离开"

但不知道:

  • 是前进还是后退
  • 是栈变化还是 replace
  • 是用户意图还是系统跳转

❗ 3. KeepAlive 会"冻结组件"

导致动画和生命周期错位。


3. 原理讲解(核心设计思想)

@giszhc/vue-page-motion 本质做了三件事:

✔ ① 路由栈方向识别

判断 forward / back

✔ ② 动画策略抽象

支持:

  • 固定动画
  • 函数动态动画
  • route.meta 控制

✔ ③ KeepAlive 解耦

动画和缓存不再互相污染


👉 关键思想一句话:

"动画不应该由组件决定,而应该由路由语义驱动。"


4. 常见错误或误区

❌ 误区1:直接写 transition wrapper

很多人这样写:

html 复制代码
<transition name="slide-left">
  <router-view />
</transition>

问题:

  • 永远一个方向
  • back 行为错误
  • 无法扩展策略

❌ 误区2:KeepAlive 全局开启

结果:

  • 表单不刷新
  • 页面状态"鬼畜残留"

❌ 误区3:动画和路由耦死

写在组件里 = 后期维护灾难


5. 解决方案(分层设计)

我们把系统拆成三层:

🧠 路由层

判断 forward / back

🎬 动画层

transition strategy

🧩 渲染层

TransitionRouterView


6. 工程实现(核心代码)

✔ 安装

bash 复制代码
pnpm install @giszhc/vue-page-motion

✔ 基础使用

html 复制代码
<template>
  <TransitionRouterView />
</template>

<script setup>
import { TransitionRouterView } from '@giszhc/vue-page-motion'
import '@giszhc/vue-page-motion/dist/index.css'
</script>

✔ 插件方式(推荐)

js 复制代码
import { createApp } from 'vue'
import App from './App.vue'
import VuePageMotion from '@giszhc/vue-page-motion'
import '@giszhc/vue-page-motion/dist/index.css'

createApp(App)
  .use(VuePageMotion)
  .mount('#app')

✔ KeepAlive 实战(踩坑重点)

vue 复制代码
<TransitionRouterView
  :keep-alive="true"
  :include="['Home', 'About']"
/>

👉 真实坑点:

  • include 名称必须是组件 name
  • 不然缓存"完全失效但不报错"

这类问题最折磨人 😅


✔ 动画策略(核心亮点)

1️⃣ 固定动画

vue 复制代码
<TransitionRouterView transition="slide-left" />

2️⃣ 动态函数(工程常用)

js 复制代码
const getTransition = (route, direction) => {
  if (route.meta.noAnimation) {
    return ''
  }

  return direction === 'forward'
    ? 'slide-left'
    : 'slide-right'
}
vue 复制代码
<TransitionRouterView :transition="getTransition" />

👉 适用于:

  • GIS地图页禁动画
  • 表单页弱动画
  • dashboard 强动画

3️⃣ route.meta 驱动(最优雅)

js 复制代码
{
  path: '/special',
  component: SpecialPage,
  meta: {
    transition: 'slide-right'
  }
}

8. 性能 & 优化建议

⚡ 1. 避免全量 KeepAlive

只缓存高频页面:

js 复制代码
include: ['Home', 'Dashboard']

如果这篇文章对你有帮助,欢迎点赞 👍 收藏 ⭐ 关注 👀

完结,撒花✿✿ヽ(°▽°)ノ✿

相关推荐
kyriewen6 小时前
别再 console.log 了:5 个 Chrome DevTools 调试技巧,用过就回不去了
前端·javascript·面试
IT_陈寒8 小时前
Python搞不定字符串编码?这破玩意坑我两小时!
前端·人工智能·后端
To_OC8 小时前
LC 1 两数之和:面试第一道必考题,暴力解法直接被面试官 pass
javascript·算法·leetcode
DigitalOcean9 小时前
Laravel 开发者已在 DigitalOcean 上开通超过 10 万台服务器
前端·laravel
星始流年9 小时前
从 Tool 到 Skill——基于 LangChain 的服务端Skill实现
前端·langchain·agent
李惟10 小时前
开源本地通信库,纯客户端 RPC,像聊天一样通信
前端
YAwu1110 小时前
深入解析 React 炫彩鼠标跟随标题组件:从坐标定位到动画性能
前端·react.js
GuWenyue10 小时前
排序效率低?5分钟吃透快速排序,性能飙升至O(nlogn)
前端·javascript·面试
OpenTiny社区10 小时前
🎨 看完 GenUI SDK 源码我悟了!
前端·vue.js·github
叁两10 小时前
前端转型AI Agent该如何学习?(前置篇)
前端·人工智能·node.js