一、vue动画实现原理:
  动画的实现,必须通过元素的显示隐藏或销毁创建。v-show  v-if
  vue中如果需要使用动画的时候,需要使用一个内置组件transition组件 该组件有一个name属性 值为动画的类名(类名随意起)
  
  实现动画有很多方式,例如:
    可以配合使用第三方 CSS 动画库,如 Animate.css

     在过渡钩子函数中使用 JavaScript 直接操作 DOM

     可以配合使用第三方 JavaScript 动画库,如 Velocity.js

  我们今天不说利用第三方动画库,自己手动利用css3 实现简单动画功能

二、动画的类名

  动画的类名分为6个

  入场动画

    <name>-enter          入场前

    <name>-enter-active    入场持续的过程

    <name>-enter-to    入场后

  出场动画

    <name>-leave      出场前
    <name>-leave-active   出场持续的过程
    <name>-leave-to      出场后
三、demo
  html和技术部分代码:通过点击按钮让盒子进行显示隐藏(v-if和v-show都可以)

通过css代码,实现具体的动画效果,本案例实现的是对盒子进行放大的动画。

  用animation做动画时,把效果给<name>-enter-active   <name>-leave-active

  或name>-enter-to<name>-leave-to都可以

四、css3 

CSS3属性中有关于制作动画的三个属性: Transition(过渡),Transform(转换),Animation(动画)
  1、transtion:
    transition-property 需要过渡的样式 (all || [attr] || none)默认是 all
    transition-duration 运动时间 默认是 0 s
    transition-delay 延迟时间 默认是 0
    transition: (过渡样式、运动时间、延迟时间)

    transition-timing-function 运动形式 默认是 ease
      ease:(慢速开始,然后变快,然后慢速结束) linear:(匀速) ease-in:(加速)
      ease-out:(减速)
      ease-in-out:(先加速后减速)
      cubic-bezier 贝塞尔曲线( x1, y1, x2, y2 )
      steps 实现一个关键逐帧动画画的功能
  2、animation: 定义动画之前先定义关键帧keyframes

  

  animation和transition的区别?
  相同点:都是随着时间改变元素的属性值。
  不同点:
    transition需要触发一个事件(hover事件或click事件等)才会随时间改变其css属性;
    而animation在不需要触发任何事件的情况下也可以显式的随着时间变化来改变元素css的属性值,从而达到一种动画的效果。

  3、transform:
                    向元素应用2D或3D转换。对元素进行旋转、缩放、移动或倾斜
    1、translate ()根据左(X轴)和顶部(Y轴)位置给定的参数,从当前元素位置移动。类似于定位中的left值(X轴)、top值(Y轴) 
            使用translate()函数,你可以把元素从原来的位置移动,而不影响在X、Y轴上任何组件。
            translate (0,500px)
    2、rotate() 在一个给定度数顺时针旋转的元素。负值是允许的,这样是元素逆时针旋转。rotate(360deg )
    3、 scale()该元素增加或减少的大小,取决于宽度(X轴)和高度(Y轴)的参数:
            缩放scale()函数让元素根据中心原点对对象进行缩放。默认的值1。因此0.01到0.99之间的任何值,使一个元素缩小;而任何大于或等于1.01的值,让元素显得更大。
  常用的transform的属性就是这些。
 
 

vue实现动画和css3动画属性的更多相关文章

  1. 使用jquery封装的动画脚本(无动画、css3动画、js动画)

    自己封装好的showhide.js 包含无动画.css3动画.js动画 包括:fade(淡入淡出)  slideUpDown(上下滑动)  slideLeftRight(左右滑动)  fadeSlid ...

  2. 关于JS动画和CSS3动画的性能差异

    本文章为综合其它资料所得. 根据Google Developer,Chromium项目里,渲染线程分为main thread和compositor thread. 如果CSS动画只是改变transfo ...

  3. JS动画与CSS3动画

    Js动画 show / hide var div = $('#test-show-hide'); div.show('slow'); // 在0.6秒钟内逐渐显示 div.hide(3000); // ...

  4. js动画和css3动画的区别

    JS动画(逐帧动画) 首先,在js动画是逐帧动画,是在时间帧上逐帧绘制帧内容,由于是一帧一帧的话,所以他的可操作性很高,几乎可以完成任何你想要的动画形式.但是由于逐帧动画的帧序列内容不一样,会增加制作 ...

  5. 高性能 CSS3 动画

    注:本文出自腾讯AlloyTeam的元彦,文章也可以在github上浏览.请尊重版权,转载请注明来源,多谢-- 高性能移动Web相较PC的场景需要考虑的因素也相对更多更复杂,我们总结为以下几点: 流量 ...

  6. CSS3 动画一瞥

    伴随HTML5而来的CSS3让前端大湿们可以用简单的CSS样式即可写出动画效果来,而在这之前,一提到动画我们可能会想到JavaScript,Flash,Java插件等.如果是用JavaScript那倒 ...

  7. CSS3动画(性能篇)

    写在前面 高性能移动Web相较PC的场景需要考虑的因素也相对更多更复杂,我们总结为以下几点: 流量.功耗与流畅度. 在PC时代我们更多的是考虑体验上的流畅度,而在Mobile端本身丰富的场景下,需要额 ...

  8. CSS3 动画animation

    关键帧 什么是关键帧.一如上面对Flash原理的描述一样,我们知道动画其实由许多静态画面组成,第一个这样的静态画面可以表述为一帧.其中关键帧是在动画过程中体现了物理明显变化的那些帧. 比如之前的例子中 ...

  9. css3动画animate

    CSS3 动画 通过 CSS3,我们能够创建动画,这可以在许多网页中取代动画图片.Flash 动画以及 JavaScript. @keyframes 定义动画关键帧: @keyframes anima ...

随机推荐

  1. Debian Buster升级后找不到声卡

    昨天将Debian从Stretch升级到了新版巴斯光年(Buster).仍旧是先将source.list中的stretch替换为buster,再执行apt-get的update.upgrade.dis ...

  2. python中pip相关命令

    用pip安装第三方包的命令 pip install xxx --user 用pip更新第三方包 pip install --upgrade xxx --user 用pip卸载第三方包 pip unin ...

  3. 微信小程序登录 code 40029 天坑

    微信登录时 code 大坑(服务端返回如下代码) {"errcode":40029,"errmsg":"invalid code, hints: [ ...

  4. 在cmd上执行关于java的反编译

    反编译是指通过对他人软件的目标程序(比如可执行程序)进行“逆向分析.研究”工作,以推导出他人的软件产品所使用的思路.原理.结构.算法.处理过程.运行方法等设计要素,某些特定情况下可能推导出源代码.反编 ...

  5. sqli--labs(25)

    过滤了 or and 的get注入 0X01测试阶段 ’报错 ” 不报错 那么就是'闭合 好的我们知道闭合后来#闭合后面 ?id= 语法不正确 发现过滤了 or and 那么我们继续构造 ?id= 0 ...

  6. @清晰掉 malloc是如何分配内存的?

    任何一个用过或学过C的人对malloc都不会陌生.大家都知道malloc可以分配一段连续的内存空间,并且在不再使用时可以通过free释放掉.但是,许多程序员对malloc背后的事情并不熟悉,许多人甚至 ...

  7. 关于Anaconda的虚拟环境操作

    # 1.创建虚拟环境 conda create -n env_name python==版本号 # 2.激活虚拟环境 conda activate env_name # 3.下载相关模块 pip in ...

  8. 阶段3 1.Mybatis_09.Mybatis的多表操作_9 mybatis多对多操作-查询用户获取用户所包含的角色信息

    sql语句以user作为主表 用户的全部信息,以为用户下的角色的.并不是所有的用户都有角色,有角色的就带角色.没角色的就为null 首先修改实体类 定义List<Role> 生成gette ...

  9. robotframework的变量的使用

    本篇用以记录RF的变量的使用 目录 1.简要介绍 2.使用关键字添加变量 3.使用菜单添加变量 1.简要介绍 RF可以通过菜单和关键字来添加变量,可以根据自己的需求来选择添加变量的方式 2.使用关键字 ...

  10. Java使用JDBC连接Hive

    最近一段时间,处理过一个问题,那就是hive jdbc的连接问题,其实也不是大问题,就是url写的不对,导致无法连接.问题在于HiveServer2增加了别的安全验证,导致正常的情况下,传递的参数无法 ...