前端笔记:css3动画transition和animation

简介: 前端笔记:css3动画transition和animation

css3动画

分类:

  • 帧动画
  • 过渡动画

CSS3动画属性:

  • transition
  • animation

常用属性

  • transform

动画库:

  • swiper
  • vue-transition

  • animate.css

transition过渡

语法

transition: property duration timing-function delay;

属性名称property


过渡时间duration


时间函数timing-function


延迟时间delay


2、注意:


display不能和transition一起使用


transition后面尽量不要跟all


常见闪动可以persp和backface-visibility


.box{
    width: 200px;
    height: 200px;
    background-color: #000000;
    margin-bottom: 20px;
}
// 鼠标经过变化宽度
.trasition-1{
    // transition: width 2s linear 1s;
    transition: width 2s linear;
    &:hover{
        width: 500px;
    }
}
// 鼠标经过旋转
.trasition-2{
    transition: transform 2s ease-out;
    &:hover{
        transform: rotate(45deg);
    }
}

animation动画

语法

animation: name duration timing-function delay iteration-count direction fill-mode play-state;

动画名称(name)@keyframes

过渡时间(duration)

时间函数(timing-function)

延迟时间(delay)

播放次数(iteration-count)

播放方向(direction)轮流播放和反向播放

停止播放的状态(fill-mode)

是否暂停(play-state)

.box{
    width: 200px;
    height: 200px;
    background-color: #000000;
    margin-bottom: 20px;
}
// 鼠标经过移动
.animation-1{
    &:hover{
        animation: move 2s linear;
    }
}
@keyframes move{
    100%{
        transform: translateX(200px);
    }
}
// 小球滚动
.animation-2{
    border-radius: 50%;
    animation: jump 2s cubic-bezier(0.4,-0.04, 0.94, 0.29) infinite;
}
@keyframes jump{
    0%{
        transform: translateX(0px);
    }
    40%{
        transform: translateX(200px);
    }
    60%{
        transform: translateX(200px);
        clip-path: ellipse(50% 50% at 50% 50%);
    }
    100%{
        transform: translateX(0px);
        clip-path: ellipse(50% 45% at 50% 48%);
    }
}
// 菊花图旋转
.animation-3{
    width: 100px;
    height: 111px;
    animation: round 1s steps(12) infinite;
    background: url(./loading.jpg) no-repeat;
}
@keyframes round{
    100%{
        transform: rotate(360deg);
    }
}

时间函数

时间函数:管理动画在单位帧内播放的速度曲线

三次贝塞尔函数的数学函数

预设值:

  • linear 匀速
  • ease
  • ease-in
  • ease-out
  • ease-in-out

steps作用是每一个关键帧,而不是整个时间

过渡和动画在js中的监听

animationstart

animationend

trasitionend

animationitertion

// 过渡事件监听
let transitionend = ()=>{
    console.log("transitionend");
}
let $box = document.querySelector('.trasition-1');
// IE FireFox已经支持
$box.addEventListener("transitionend", transitionend);
// 360 safari chrome下需要兼容处理
$box.addEventListener("WebkitTransitionend", transitionend);
相关文章
|
2月前
|
前端开发 算法 Java
【CSS】前端三大件之一,如何学好?从基本用法开始吧!(九):强势分析Animation动画各类参数;从播放时间、播放方式、播放次数、播放方向、播放状态等多个方面,完全了解CSS3 Animation
Animation属性 css3为Animation动画提供的几个属性如下: 属性名 属性值 animation-name 指定动画名称,该属性指定一个已有的关键帧定义。 animation-duration 指定动画持续时间。 animation-timing-funtion 指定动画变化速度。 animation-delay 指定动画延迟多长时间才开始执行。 animation-iteration-count 指定动画的循环执行次数。 animation:这是一个复合属性。
235 1
|
前端开发 JavaScript
前端 css 经典:transition 过渡和 animation 动画
前端 css 经典:transition 过渡和 animation 动画
260 2
|
前端开发 JavaScript 内存技术
css动画animation绘制向四周扩散的圆圈
css动画animation绘制向四周扩散的圆圈
1591 0
CSS3 animation 全屏图片切换动画
CSS3 animation 全屏图片切换动画
141 0
CSS3 animation 大海波涛动画
CSS3 animation 大海波涛动画
191 0
CSS3 animation 无缝滚动,鼠标悬浮暂停
CSS3 animation 无缝滚动,鼠标悬浮暂停
197 0
CSS3动画属性之Animation
CSS3动画属性之Animation
262 0
|
前端开发
【不一样的CSS】这些关于transition和animation的小细节,你知道吗?
关于transition和animation这两个CSS3属性想必大家都知道,这两个属性都是非常常用的属性,本篇文章来介绍一下关于transition和animation这两个的细节。
292 0
【不一样的CSS】这些关于transition和animation的小细节,你知道吗?
11、CSS3的动画效果(animation)
11、CSS3的动画效果(animation)
246 0
11、CSS3的动画效果(animation)

热门文章

最新文章

  • 1
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(九):强势分析Animation动画各类参数;从播放时间、播放方式、播放次数、播放方向、播放状态等多个方面,完全了解CSS3 Animation
    235
  • 2
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(八):学习transition过渡属性;本文学习property模拟、duration过渡时间指定、delay时间延迟 等多个参数
    225
  • 3
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(七):学习ransform属性;本文学习 rotate旋转、scale缩放、skew扭曲、tanslate移动、matrix矩阵 多个参数
    164
  • 4
    (CSS)使用Flex布局,帮助你快速了解各种基本的Flex布局属性以及帮你让元素快速达到布局中的指定位置!
    133
  • 5
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(六):全方面分析css的Flex布局,从纵、横两个坐标开始进行居中、两端等元素分布模式;刨析元素间隔、排序模式等
    275
  • 6
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(五):背景属性;float浮动和position定位;详细分析相对、绝对、固定三种定位方式;使用浮动并清除浮动副作用
    408
  • 7
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(四):元素盒子模型;详细分析边框属性、盒子外边距
    176
  • 8
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(三):元素继承关系、层叠样式规则、字体属性、文本属性;针对字体和文本作样式修改
    112
  • 9
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(二):CSS伪类:UI伪类、结构化伪类;通过伪类获得子元素的第n个元素;创建一个伪元素展示在页面中;获得最后一个元素;处理聚焦元素的样式
    190
  • 10
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(一):CSS发展史;CSS样式表的引入;CSS选择器使用,附带案例介绍
    261