0

0

Vue的过渡动画如何实现?transition组件怎么用?

冰火之心

冰火之心

发布时间:2025-06-03 09:12:02

|

551人浏览过

|

来源于php中文网

原创

vue 的过渡动画通过 transition 组件实现,用于元素插入、更新或移除时添加效果。一、transition 包裹单个元素,如 包裹一个 dom 元素,通过 v-if 控制显示隐藏,vue 会自动添加 .fade-enter-active 和 .fade-leave-active 等类名控制过渡;二、transition-group 处理列表动画,需配合 v-for 使用,每个子元素必须有 key 属性,并可通过 tag 指定渲染的标签;三、javascript 钩子可精细控制动画逻辑,如 @before-enter、@enter、@after-enter 等钩子可在动画各阶段执行自定义操作,适合结合第三方动画库使用;四、注意问题包括确保状态变化触发动画、v-show 不支持 js 钩子、name 属性影响类名前缀等要点。

Vue的过渡动画如何实现?transition组件怎么用?

Vue 的过渡动画其实主要靠 transition 组件来实现,它是一个内置组件,用来在元素插入、更新或移除时添加过渡效果。用好了这个组件,页面切换、弹窗显示这些操作就能更自然,用户体验也会更好。


一、transition 包裹单个元素,是最常见用法

通常包裹一个单独的 DOM 元素或者组件。比如你有一个按钮控制显示隐藏的提示框,就可以这样写:


  

这是一个提示

show 变为 true 或 false 时,Vue 会自动检测进入和离开的状态,并在相应阶段添加 CSS 过渡类名,比如 .fade-enter-active, .fade-leave-active 等。

立即学习前端免费学习笔记(深入)”;

对应的 CSS:

.fade-enter-active, .fade-leave-active {
  transition: opacity 0.3s;
}
.fade-enter, .fade-leave-to {
  opacity: 0;
}

注意一点:只能包裹一个根元素。如果你在里面写了多个元素,比如两个

并列,那 Vue 会报错或者不生效。

二、transition-group 处理列表过渡动画

如果你要给 v-for 渲染出来的列表加上动画,就不能再用普通的 ,得换成

比如一个简单的待办事项列表:

Type Studio
Type Studio

一个视频编辑器,提供自动转录、自动生成字幕、视频翻译等功能

下载

  
  • {{ item.text }}
  • 这里的 tag="ul" 指定最终渲染成哪个标签,否则默认是 。CSS 动画写法和上面类似,但要注意的一点是:使用 时,每个子元素必须有 key 属性,这是 Vue 判断元素唯一性的依据。


    三、用 JavaScript 钩子做更精细控制

    大多数情况用 CSS 写过渡就够用了。但如果想在动画过程中执行一些逻辑,比如在动画结束后发送请求、修改数据等,可以用 JavaScript 钩子。

    支持的钩子包括:

    • @before-enter
    • @enter
    • @after-enter
    • @enter-cancelled
    • @before-leave
    • @leave
    • @after-leave
    • @leave-cancelled

    举个例子,你想在元素进入时滚动到底部,可以这样写:

    
      

    动态内容

    methods: {
      beforeEnter(el) {
        el.style.opacity = 0;
      },
      enter(el, done) {
        // 手动控制动画结束
        setTimeout(() => {
          el.style.opacity = 1;
          done(); // 必须调用 done(),否则 after-enter 不会触发
        }, 300);
      }
    }

    这种写法适合需要结合第三方动画库(比如 GSAP)的情况。


    四、注意几个容易出问题的地方

    1. 过渡状态没变化,动画不会触发
      比如你只是改了某个类名,但 DOM 没有插入或移除,这时候动画可能不会运行。确保你是通过 v-ifv-showv-for 来改变节点的存在状态。

    2. v-show 和 v-if 的区别
      支持 v-ifv-show,但 v-show 是通过 display 控制显隐,所以不能配合 JavaScript 进入/离开钩子一起用。

    3. name 属性决定类名前缀
      如果你不写 name,默认会用 v-enterv-leave 这样的类名。建议自己指定 name,避免和其他样式冲突。


    基本上就这些。Vue 的过渡机制虽然功能强大,但理解清楚生命周期钩子和类名规则之后,用起来还是很顺手的。

    相关专题

    更多
    js获取数组长度的方法
    js获取数组长度的方法

    在js中,可以利用array对象的length属性来获取数组长度,该属性可设置或返回数组中元素的数目,只需要使用“array.length”语句即可返回表示数组对象的元素个数的数值,也就是长度值。php中文网还提供JavaScript数组的相关下载、相关课程等内容,供大家免费下载使用。

    554

    2023.06.20

    js刷新当前页面
    js刷新当前页面

    js刷新当前页面的方法:1、reload方法,该方法强迫浏览器刷新当前页面,语法为“location.reload([bForceGet]) ”;2、replace方法,该方法通过指定URL替换当前缓存在历史里(客户端)的项目,因此当使用replace方法之后,不能通过“前进”和“后退”来访问已经被替换的URL,语法为“location.replace(URL) ”。php中文网为大家带来了js刷新当前页面的相关知识、以及相关文章等内容

    374

    2023.07.04

    js四舍五入
    js四舍五入

    js四舍五入的方法:1、tofixed方法,可把 Number 四舍五入为指定小数位数的数字;2、round() 方法,可把一个数字舍入为最接近的整数。php中文网为大家带来了js四舍五入的相关知识、以及相关文章等内容

    731

    2023.07.04

    js删除节点的方法
    js删除节点的方法

    js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

    477

    2023.09.01

    JavaScript转义字符
    JavaScript转义字符

    JavaScript中的转义字符是反斜杠和引号,可以在字符串中表示特殊字符或改变字符的含义。本专题为大家提供转义字符相关的文章、下载、课程内容,供大家免费下载体验。

    394

    2023.09.04

    js生成随机数的方法
    js生成随机数的方法

    js生成随机数的方法有:1、使用random函数生成0-1之间的随机数;2、使用random函数和特定范围来生成随机整数;3、使用random函数和round函数生成0-99之间的随机整数;4、使用random函数和其他函数生成更复杂的随机数;5、使用random函数和其他函数生成范围内的随机小数;6、使用random函数和其他函数生成范围内的随机整数或小数。

    991

    2023.09.04

    如何启用JavaScript
    如何启用JavaScript

    JavaScript启用方法有内联脚本、内部脚本、外部脚本和异步加载。详细介绍:1、内联脚本是将JavaScript代码直接嵌入到HTML标签中;2、内部脚本是将JavaScript代码放置在HTML文件的`<script>`标签中;3、外部脚本是将JavaScript代码放置在一个独立的文件;4、外部脚本是将JavaScript代码放置在一个独立的文件。

    657

    2023.09.12

    Js中Symbol类详解
    Js中Symbol类详解

    javascript中的Symbol数据类型是一种基本数据类型,用于表示独一无二的值。Symbol的特点:1、独一无二,每个Symbol值都是唯一的,不会与其他任何值相等;2、不可变性,Symbol值一旦创建,就不能修改或者重新赋值;3、隐藏性,Symbol值不会被隐式转换为其他类型;4、无法枚举,Symbol值作为对象的属性名时,默认是不可枚举的。

    551

    2023.09.20

    高德地图升级方法汇总
    高德地图升级方法汇总

    本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

    9

    2026.01.16

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    Sass 教程
    Sass 教程

    共14课时 | 0.8万人学习

    Bootstrap 5教程
    Bootstrap 5教程

    共46课时 | 2.9万人学习

    CSS教程
    CSS教程

    共754课时 | 19.4万人学习

    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

    Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号