IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 游戏开发 -> Vue封装的过渡与动画 -> 正文阅读

[游戏开发]Vue封装的过渡与动画

一、不使用Vue封装的动画效果

实现步骤:

  1. 首先在template标签里面准备html结构,控制动画的按钮和需要做动画的元素
  2. 在script标签里面定义一个关键帧@keyframes,里面书写要实现的动画
  3. 有了动画得使用,可以通过类名去给标签元素添加动画,所以需要定义两个样式类名通过animation属性来控制动画效果
  4. 最后给元素绑定类名,通过动态的使用回调来控制类名的切换

代码示例:

<template>
  <div>
      <button @click="isShow=!isShow">显示/隐藏</button>
      <h1 v-show="isShow" class="come">我是动画效果</h1>
  </div>
</template>

<script>
    export default {
        name:'Test',
        data() {
            return {
                isShow:true
            }
        },
    }
</script>

<style scoped>
    h1{
        background-color: aqua;
    }
    .come{
        animation: moveShow 1s linear;
    }
    .go{
        animation: moveShow 1s reverse linear;
    }

    @keyframes moveShow {
        from{
            transform: translateX(-100%);
        }
        to{
            transform: translateX(0px);
        }
    }
</style>

二、使用Vue封装的动画效果

要求:

  1. 想要哪个元素发生动画,就使用transition标签包裹起来这个元素
  2. 如果定义了关键帧@keyframes,控制动画效果的类名不能乱写,必须写成v-enter-active、v-leave-active,此时类名也不要写在标签元素里面了

注意:

  1. transition标签都可以有一个name属性,当使用name属性之后,控制动画的类名就不能是v-k开头了,得写成name的值-enter-active,继续使用v-开头不会报错,但是动画效果没了
  2. 打开页面刷新不会有动画效果,只有点击按钮才会有动画效果,此时,如果想要一刷新页面就产生动画效果,可以使用appear属性

代码示例:

<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: aqua;
    }
    .hello-enter-active{
        animation: moveShow 1s linear;
    }
    .hello-leave-active{
        animation: moveShow 1s reverse linear;
    }

    @keyframes moveShow {
        from{
            transform: translateX(-100%);
        }
        to{
            transform: translateX(0px);
        }
    }
</style>

三、使用Vue封装的过渡效果

首先要知道Vue给我们准备几个样式:

  • 元素进入的样式:
    ? ? ? ? 1. v-enter:进入的起点
    ? ? ? ? 2. v-enter-active:进入过程中
    ? ? ? ? 3. v-enter-to:进入的终点
  • 元素离开的样式:
    ? ? ? ? 1. v-leave:离开的起点
    ? ? ? ? 2. v-leave-active:离开过程中
    ? ? ? ? 3. v-leave-to:离开的终点

假如我们要实现以上相同的动画效果,首先我们要在样式里面写相应的过渡效果,以及在需要做动画的标签样式里面写上过渡的时间。

示例代码:

<style scoped>
    h1{
        background-color: aqua;
        /* 过渡时间 */
        transition: 0.5s linear;
    }
    /* 进入的起点 */
    .hello-enter{
        transform: translateX(-100%);
    }
    /* 进入的终点 */
    .hello-enter-to{
        transform: translateX(0);
    }
    /* 离开的起点 */
    .hello-leave{
        transform: translateX(0);
    }
    /* 离开的终点 */
    .hello-leave-to{
        transform: translateX(-100%);
    }
</style>

观察一下会发现,添加过渡时间在元素标签内会破坏原有的标签样式,进入的起点和离开的终点是相同的,进入的终点和离开的起点是相同的,所以上面的样式代码可以优化一下,优化后代码如下:

<style scoped>
    h1{
        background-color: aqua;
    }
    /* 进入的起点,离开的终点 */
    .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>

四、使用Vue封装多个元素过渡

以上的代码示例说的都是单个元素的过渡,但是在正常开发当中,多个元素过渡使用居多,现在我们来一起看看多个元素过渡如何封装,其实很简单。使用<transition-group></transition-group>标签包裹着多个元素,但是这样子还是不行会报错,此时还需要给每个元素加上不同的key属性值才可以。

示例代码:

   <transition-group name="hello" appear>
      <h1 v-show="isShow" key="1">我是动画效果</h1>
      <h1 v-show="isShow" key="2">我是动画效果</h1>
   </transition-group>

五、使用集成第三方动画库来实现动画效果

推荐一个npm上的animate.css动画库:

?使用步骤:

  1. 安装动画库:npm install animate.css
  2. 在要使用的组件内引入库:import 'animate.css'
  3. 复制类名"animate__animated animate__bounce"到transition标签的name属性
  4. 复制进入动画的类名到enter-active-class属性,复制退出动画的类名到leave-active-class属性,就可以实现动画了

示例代码:

<template>
  <div>
   <button @click="isShow=!isShow">显示/隐藏</button>
   <transition-group 
   appear 
   name="animate__animated animate__bounce" enter-active-class="animate__swing"
   leave-active-class="animate__bounceOutUp"
   >
      <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: aqua;
    }
</style>

效果展示:

?六、总结

Vue封装的过渡与动画

  1. 作用:在插入、更新或移除 DOM元素时,在合适的时候给元素添加样式类名。
  2. 写法:

    ? ?1. 准备好样式:

    ? ? ? - 元素进入的样式:
    ? ? ? ? 1. v-enter:进入的起点
    ? ? ? ? 2. v-enter-active:进入过程中
    ? ? ? ? 3. v-enter-to:进入的终点
    ? ? ? - 元素离开的样式:
    ? ? ? ? 1. v-leave:离开的起点
    ? ? ? ? 2. v-leave-active:离开过程中
    ? ? ? ? 3. v-leave-to:离开的终点

    ? ?2. 使用<transition>包裹要过度的元素,并配置name属性:
    ? ? ? <transition name="hello">
    ? ? ? ?? ?<h1 v-show="isShow">你好啊!</h1>
    ? ? ? </transition>

  3. 备注:若有多个元素需要过度,则需要使用:```<transition-group>```,且每个元素都要指定```key```值。

  游戏开发 最新文章
6、英飞凌-AURIX-TC3XX: PWM实验之使用 GT
泛型自动装箱
CubeMax添加Rtthread操作系统 组件STM32F10
python多线程编程:如何优雅地关闭线程
数据类型隐式转换导致的阻塞
WebAPi实现多文件上传,并附带参数
from origin ‘null‘ has been blocked by
UE4 蓝图调用C++函数(附带项目工程)
Unity学习笔记(一)结构体的简单理解与应用
【Memory As a Programming Concept in C a
上一篇文章      下一篇文章      查看所有文章
加:2022-05-05 11:52:21  更:2022-05-05 11:54:01 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/23 10:45:36-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码