• Vue 过渡与动画


    Vue封装的过渡与动画: 在插入、更新或移除DOM元素时,在合适的时候给元素添加样式类名。

    在这里插入图片描述
    写法:

    1. 准备好样式:
      • 元素进入的样式:
        1. v-enter:进入的起点
        2. v-enter-active:进入过程中
        3. v-enter-to:进入的终点
      • 元素离开的样式:
        1. v-leave:离开的起点
        2. v-leave-active:离开过程中
        3. v-leave-to:离开的终点
    2. 使用====包裹要过度的元素,并配置name属性,此时需要将上面样式名为 v 换为 name
    3. 要让页面一开始就显示动画,需要添加appear
    <transition name="hello" appear>
      <h1 v-show="isShow">你好啊!</h1>
    </transition>
    
    <style>
      .hello-enter-active{
        animation: hello 0.5s linear;
      }
    
      .hello-leave-active{
        animation: hello 0.5s linear reverse;
      }
    
      @keyframes hello {
        from{
          transform: translateX(-100%);
        }
        to{
          transform: translateX(0px);
        }
      }
    </style
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22

    4.备注: 若有多个元素需要过渡,则需要使用 ,且每个元素都要指定 key值

    <transition-group name="hello" appear>
      <h1 v-show="!isShow" key="1">你好啊!</h1>
      <h1 v-show="isShow" key="2">尚硅谷!</h1>
    </transition-group>
    
    
    • 1
    • 2
    • 3
    • 4
    • 5

    5.第三方动画库 Animate.css 网站:https://www.npmjs.com/package/animate.css

    安装完成后,直接引用样式 import ‘animate.css’

    <transition-group appear
              name="animate__animated animate__bounce"
              enter-active-class="animate__swing"
              leave-active-class="animate__backOutUp">
      <h1 v-show="!isShow" key="1">你好啊!</h1>
      <h1 v-show="isShow" key="2">尚硅谷!</h1>
    </transition-group>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    src/App.vue

    <template>
    	<div>
    		<Test/>
    		<Test2/>
    		<Test3/>
    	</div>
    </template>
    
    <script>
    	import Test from './components/Test'
    	import Test2 from './components/Test2'
    	import Test3 from './components/Test3'
    
    	export default {
    		name:'App',
    		components:{Test,Test2,Test3},
    	}
    </script>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18

    src/components/test.vue

    <template>
      <div>
        <button @click="isShow = !isShow">显示/隐藏</button>
        <transition name="hello" appear>
          <h1 v-show="isShow">你好啊!</h1>
        </transition>
      </div>
    </template>
    
    <script>
      export default {
        name: 'Test',
        data() {return {isShow:true}},
      }
    </script>
    
    <style scoped>
      h1{background-color: orange;}
    
      .hello-enter-active{
        animation: atguigu 0.5s linear;
      }
    
      .hello-leave-active{
        animation: atguigu 0.5s linear reverse;
      }
    
      @keyframes atguigu {
        from{transform: translateX(-100%);}
        to{transform: translateX(0px);}
      }
    </style>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32

    src/components/test2

    <template>
      <div>
        <button @click="isShow = !isShow">显示/隐藏</button>
        <transition-group name="hello" appear>
          <h1 v-show="!isShow" key="1">你好啊!</h1>
          <h1 v-show="isShow" key="2">尚硅谷!</h1>
        </transition-group>
      </div>
    </template>
    
    <script>
      export default {
        name:'Test',
        data() {return {isShow:true}},
      }
    </script>
    
    <style scoped>
      h1 {
        background-color: orange;
        /* transition: 0.5s linear; */
      }
      /* 进入的起点、离开的终点 */
      .hello-enter,.hello-leave-to {
        transform: translateX(-100%);
      }
      .hello-enter-active,.hello-leave-active{
        transition: 0.5s linear;
      }
      /* 进入的终点、离开的起点 */
      .hello-enter-to,.hello-leave {
        transform: translateX(0);
      }
    </style>
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35

    src/components/test3

    <template>
      <div>
        <button @click="isShow = !isShow">显示/隐藏</button>
        <transition-group appear
                          name="animate__animated animate__bounce"
                          enter-active-class="animate__swing"
                          leave-active-class="animate__backOutUp">
          <h1 v-show="!isShow" key="1">你好啊!</h1>
          <h1 v-show="isShow" key="2">尚硅谷!</h1>
        </transition-group>
      </div>
    </template>
    
    <script>
      import "animate.css"
      
      export default {
        name: "Test",
        data() {return {isShow: true,}},
      };
    </script>
    
    <style scoped>
      h1 {background-color: orange;}
    </style>
    
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
  • 相关阅读:
    C++中将 sizeof() 用于类
    【CVPR2022】用于域适应语义分割的域无关先验
    【LeetCode】311d:字符串的前缀分数和
    【Java异常易错点】try或catch语句块中return后,finally还会执行吗?
    Next.js下通过env分环境控制功能开关
    web流程设计器andflow_js已支持独立配置节点样式
    centos7安装配置MySQL8
    spring.profiles.active 未生效问题解决
    绑定支付卡表单页面html页面前端源码
    蓝桥杯打卡Day13天
  • 原文地址:https://blog.csdn.net/fd2025/article/details/125430411