Vue学习:Vue中CSS动画原理

本文介绍了在Vue中如何使用transition标签实现CSS动画,通过解析Vue如何处理动画流程,详细阐述了显示和隐藏时的动画过程,并提供了基础代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Vue学习:Vue中CSS动画原理

一、例子
1.1 基础代码

代码实现了点击按钮hello derrick显示或者消失,现在需要添加过度效果

<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Hello Derrick</title>
        <script src="./vue.js"></script>
    </head>
    <body>
        <div id="app">
            <div id="root">
                <div v-if="show">hello derrick</div>
                <button @click="handleClick">切换</button>
            </div>
        </div>
    </body>
    <script>
        var vm = new Vue({
            el:'#root',
            data:{
                show:true
            },
            methods:{
                handleClick:function(){
                    this.show = !this.show
                }
            }
        })
    </script>
</html>
1.2 transition标签

transition标签里面包裹说明里面包裹的内容有动画效果,当有标签被transition标签包裹后,Vue会分析标签CSS样式,构建动画流程:

1.2.1 显示的动画流程
  • 开始:动画即将开始执行瞬间添加这两个fade-enter、fade-enter-active的class名字
  • 过程:删除fade-enter、添加fade-enter-to的class名字
  • 最后:删除fade-enter-active、fade-enter-to这两个class名字

在这里插入图片描述

1.2.2 隐藏的动画流程

在这里插入图片描述

1.2.3 代码
        <style>
            .v-enter{
                opacity: 0;
            }
            .v-enter-active{
                transition: opacity 3s;
            }
            .v-leave-to{
                opacity: 0;
            }
            .v-leave-active{
                transition: opacity 3s;
            }
        </style>
    </head>
    <body>
        <div id="app">
            <div id="root">
                <transition name="fade">
                    <!--也可以写动态组件-->
                    <div v-if="show">hello derrick</div>
                </transition>
                <button @click="handleClick">切换</button>
            </div>
        </div>
    </body>
    <script>
        var vm = new Vue({
            el:'#root',
            data:{
                show:true
            },
            methods:{
                handleClick:function(){
                    this.show = !this.show
                }
            }
        })
    </script>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值