CSS自学笔记(14):CSS3动画效果
在CSS3中也新增了一些能够对元素创建动画处理的属性。通过这些新增的属性,我们可以实现元素从一种样式变换成另一种样式时为元素添加动态效果,我们就可以取代网页中的动态图片、flash动画和JavaScript了。
CSS3中新增的动画效果的属性以及主流浏览器支持情况
| 属性 | 浏览器支持 | ||||
|---|---|---|---|---|---|
| transition | IE | Firefox | Chrome | Safari(-webkit-) | Opera |
| @keyframes | IE | Firefox | Chrome(-webkit-) | Safari(-webkit-) | Opera |
| animation | IE | Firefox | Chrome(-webkit-) | Safari(-webkit-) | Opera |
注:
- IE9以及更早版本不支持这三个新增属性。
- 在Safari浏览器中,需要加(-webkit-)前缀。
- 在Chrome浏览器中,@keyframes和animation属性需要加(-webkit-)前缀。
transition属性
| 属性 | 描述 | 默认值 |
|---|---|---|
| transition | 简写,用于在一个属性中设置四个过渡属性。 | 无 |
| transition-property | 定义过渡效果的 CSS 属性的名称。 | 无 |
| transition-duration | 定义过渡效果所用时间。 | 0 |
| transition-timing-function | 定义过渡效果的时间曲线。 | ease |
| transition-delay | 定义过渡效果开始时间。 | 0 |
下面是一个简单的CSS样式
img {
width: 90px;
height: 90px;
transition-property: width, height, transform;
transition-duration: 1s, 1s, 1s;
transition-timing-function: ease-in-out, ease-in, ease-out;
transition-delay: 1s, 1s, 0s;
}
img:hover{
width: 200px;
height: 200px;
transform: rotate(90deg);
}
实现效果是当鼠标悬浮在元素(img)上时,他的宽度、高度和方向会发生变化,过渡时间都为1s,过渡方式分别为ease-in-out, ease-in和ease-out,旋转效果会立刻执行,而高宽操作会在1s后变化。
当鼠标移出元素所在范围时,它会逐渐变回原来的样式。

我们也可以transition简写来完成定义上面的样式:
img {
width: 90px;
height: 90px;
transition:width 1s ease-in-out 1s, height 1s ease-in 1s, transform 1s ease-out 0s; ;
}
img:hover{
width: 200px;
height: 200px;
transform: rotate(90deg);
}
我们还可以通过@keyframes规定来创建动画规则,通常用在较为复杂而又无需用到False动画和JavaScript的地方。
例如下面一个简单的动画效果
动画效果
部分CSS样式代码为:
#my_animate {
width: 60px;
height: 60px;
background: #060;
color: #fff;
position: relative;
font: bold 12px '微软雅黑';
padding: 20px 10px 0px 10px;
animation: my_animate 5s infinite;
}
@keyframes my_animate {
0% {transform: rotate(0deg);left:0px;}
25% {transform: rotate(90deg);left:0px;}
50% {transform: rotate(0deg);left:400px;}
55% {transform: rotate(0deg);left:400px;}
70% {transform: rotate(-30deg);left:400px;background:#ff9;color:#000;}
100% {transform: rotate(-360deg);left:0px;}
}
使用@keyframes创建动画时,需要绑定一个选择器。创建动画时至少要定义动画的名称和动画的时长,这样即可将@keyframes创建动画绑定到相应的选择器上。
若在创建动画时没有定义时长,那么就会取默认值0,就不会执行动画效果。
animation属性以及说明
| 属性 | 描述 | 说明 |
|---|---|---|
| @keyframes | 创建动画规则 | |
| animation | 定义动画简写属性 | 除了 animation-play-state 属性 |
| animation-name | 定义 @keyframes 动画的名称 | |
| animation-duration | 定义动画完成一个周期所花费时间(秒或者毫秒) | 默认值:0 |
| animation-timing-function | 定义动画的速度曲线 | 默认值 :ease |
| animation-delay | 定义动画何时开始 | 默认值 :0 |
| animation-iteration-count | 定义动画被播放的次数 | 默认值 :1 |
| animation-direction | 定义动画是否在下一周期逆向地播放 | 默认值 :normal |
| animation-play-state | 定义动画是否正在运行或暂停 | 默认值 :running |
| animation-fill-mode | 定义对象动画时间之外的状态 |
上面的定义的动画效果是一个周期5s,并且进行无限次的循环播放。在@keyframes中规定了动画的6各阶段的样式,最终形成一个简单的动画效果。
CSS自学笔记(14):CSS3动画效果的更多相关文章
- animate.css 一些常用的CSS3动画效果
大家已经开始在项目中使用一些CSS3动画效果了吧,这让网站在高端浏览器上看起来很上流.animate.css是一个老外做的各种CSS3动画的合集,比较全,也很炫,大家可以参考学习一下. 项目主页:ht ...
- CSS基础学习-15.CSS3 动画效果
- CSS Animatie是一款在线制作CSS3动画的工具,可以在线直接制作CSS3动画效果,生成代码
CSS Animatie是一款在线制作CSS3动画的工具,可以在线直接制作CSS3动画效果,生成代码 CSS Animatie 彩蛋爆料直击现场 CSS Animatie是一款在线制作CSS3动画的工 ...
- CSS3动画效果——js调用css动画属性并回调处理详解
http://www.jb51.net/css/258407.html 这篇文章主要详细介绍了CSS3动画效果回调处理,需要的朋友可以参考下 我们在做js动画的时候,很多时候都需要做回调处理,如在一个 ...
- 鼠标悬停css3动画效果
下载Demo 效果预览 html: <!DOCTYPE html> <html lang="en"> <head> <meta chars ...
- Bounce.js – 快速创建漂亮的 CSS3 动画效果
Bounce.js 是一个用于制作漂亮的 CSS3 关键帧动画的 JavaScript 库,使用其特有的方式生成的动画效果.只需添加一个组件,选择预设,然后你就可以得到一个短网址或者导出为 CSS 代 ...
- 第八十三节,CSS3动画效果
CSS3动画效果 学习要点: 1.动画简介 2.属性详解 3.简写和版本 本章主要探讨HTML5中CSS3的动画效果,可以通过类 Flash那样的关键帧模式控制运行. 一.动画简介 CSS3提 ...
- !!学习笔记:CSS3动画
一句话就有css3动画: 2016-6-29 <style type="text/css"> h1{background:#999;} h1:hover{border- ...
- 35个让人惊讶的CSS3动画效果
1. Pure CSS Coke Can 2. Colorful Clock 3. jQuery DJ Hero 4. Animated Pricing Column 5. Slick jQuery ...
- Css3动画效果,彩色文字效果,超简单的loveHeart
<!DOCTYPE html><html><head><meta charset="utf-8" /><title>Cs ...
随机推荐
- 纪念SlingShot 矩阵
第一次独立做矩阵,只WA了一次,好高兴~~ 题意:已知 F(n)=3 * F(n-1)+2 * F(n-2)+7 * F(n-3),n>=3,其中F(0)=1,F(1)=3,F(2)=5,对于给 ...
- JQ----树杈型导航
简单的做了一个树杈型的导航结构如下所示: 废话不多说,上代码: HTML: <div class="wrapper"> <div class="tabt ...
- 复习篇(一)Activity的生命周期和启动模式
(一)关于<intent-filter>中的<data> 当设置<data>过滤器的时候,使用intent的时候必须要设置响应的匹配,否则无法匹配成功.不过不设置则 ...
- class之cls
cls代表的是类本身,一般在静态方法中使用
- BootstrapTable+KnockoutJS实现增删改查解决方案
BootstrapTable+KnockoutJS实现增删改查解决方案 前言:上篇介绍了下ko增删改查的封装,确实节省了大量的js代码.博主是一个喜欢偷懒的人,总觉得这些基础的增删改查效果能不能通过一 ...
- shell基础——字符串连接
#!/bin/sh str1="hello" str2="world" echo str1=$str1, str2=$str2 strconn1=$str1$s ...
- 评价早期SaaS创业公司时,投资人在关注什么?(是否有机会发展成一个平台,长期的护城河)
编者按: 当聊到早期项目时,人们经常会问投资人一个问题:“在评价早期 SaaS 创业公司时,投资人会关注什么——指标还是其他方面?” Nakul Mandan 作为 Lightspeed 风投机构的合 ...
- Java实现二叉搜索树的添加,前序、后序、中序及层序遍历,求树的节点数,求树的最大值、最小值,查找等操作
什么也不说了,直接上代码. 首先是节点类,大家都懂得 /** * 二叉树的节点类 * * @author HeYufan * * @param <T> */ class Node<T ...
- pyspark 写 logistic regression
import random as rd import math class LogisticRegressionPySpark: def __init__(self,MaxItr=100,eps=0. ...
- 线性表的Java实现
一.概念 对于常用的数据结构,可分为线性结构和非线性结构,线性结构主要是线性表,非线性结构主要是数和图.当n>0时,表可表示为:(a0,a1,a2,a3,…an) 1. 线性表的特征: 1.存在 ...