CSS3 动画 cheatsheet
Transition
实例
.box {
height: 100px;
width: 100px;
background: #212121;
transition: width 1s ease, height 2s ease 1s;
}
.box:hover {
height: 200px;
width: 200px;
}
参数
- transition-property
- transition-duration
- transition-timing-function(可以 定制)
- transition-delay
js 触发
<!DOCTYPE html>
<html>
<head>
<title></title>
<style type="text/css">
.box {
height: 100px;
width: 100px;
background: #212121;
transition: width 1s ease, height 2s ease 1s;
}
.larger {
width: 200px;
height: 200px;
}
</style>
</head>
<body>
<div class="box"></div>
<script type="text/javascript">
setTimeout(() => {
document.querySelector('.box').classList.add('larger')
}, 500)
</script>
</body>
</html>
使用注意和局限
- 不是所有的 CSS 属性都支持 transition,完整列表 & 具体效果
- transition 需要明确知道开始状态和结束状态的具体数值
- transition 需要事件触发(上面例子中的 hover 或者动态添加 class),其实质是元素属性的改变,而该属性定义过 transition
- transition 是一次性的,不能重复发生,除非一再触发
- transition 只能定义开始状态和结束状态,不能定义中间状态,也就是说只有两个状态
Animation
实例
.box {
height: 100px;
width: 100px;
background: #212121;
}
@keyframes larger {
50% {
height: 200px;
width: 100px;
}
100% {
height: 200px;
width: 200px;
}
}
.box:hover {
/* CSS Animation 需要指定动画一个周期持续的时间,以及动画效果的名称 */
animation: 2s larger;
}
参数
- animation-iteration-count(动画播放次数,可以取值 1, 2, 3... 或者 infinite)
- animation-fill-mode(动画结束,会立即从结束状态跳回到开始状态,可以取值 forwards 使之保留在结束状态)
- animation-name
- animation-duration
- animation-timing-function
- animation-delay
- animation-direction(规定动画是否在下一周期逆向地播放。默认是 "normal"。)
- animation-play-state(如果想让动画保持突然终止时的状态,就要使用 animation-play-state 属性。)
js 触发
<!DOCTYPE html>
<html>
<head>
<title></title>
<style type="text/css">
.box {
height: 100px;
width: 100px;
background: #212121;
}
@keyframes larger {
50% {
height: 200px;
width: 100px;
}
100% {
height: 200px;
width: 200px;
}
}
.larger {
animation: 2s larger forwards;
}
</style>
</head>
<body>
<div class="box"></div>
<script type="text/javascript">
setTimeout(() => {
document.querySelector('.box').classList.add('larger')
}, 1000)
</script>
</body>
</html>
连续的动画
<!DOCTYPE html>
<html>
<head>
<title></title>
<style type="text/css">
.box {
height: 100px;
width: 100px;
background: #212121;
animation:
1s higher forwards,
1s 1s wider forwards;
}
@keyframes higher {
50% {
height: 100px;
}
100% {
height: 200px;
}
}
@keyframes wider {
50% {
width: 100px;
}
100% {
width: 200px;
}
}
</style>
</head>
<body>
<div class="box"></div>
</body>
</html>
如果连续的动画是作用在同一个元素上,其实完全可以写在一个 animation 里。
CSS3 动画 cheatsheet的更多相关文章
- css3动画第一式--简单翻滚
在w3cschool上面查阅css3的动画语法手册时,发现“css3 动画”栏目首页放了一个翻滚的div动画案例,觉得挺好看的,于是就自己模仿着写了一下,感觉还行O(∩_∩)O哈哈~ 查看原地址 下面 ...
- CSS3动画制作
CSS3动画制作 rotate 绕中心旋转 fadeInPendingFadeOutUp 先渐现,停留2s,再向上滑动并逐渐消失 fadeInUp2D 向上滑动并渐现, 因Animate.css的fa ...
- 学习CSS3动画(animation)
CSS3就是出了不少高大上的功能,3D效果.动画.多列等等.今天写篇文章记录怎么一下怎么用CSS3写一个动画. 丑话还得说前头,IE9以及以下版本不支持CSS3动画(如真要实现可以考虑用js,不过估计 ...
- 用CSS3动画,让页面动起来
以前就听说过有个库,叫animate.css,但是自己并没有在实际项目中使用过,这次正好要做个招聘页面,得以利用一下这个库,在经常会卡顿的UC浏览器中也能流畅执行. 扫描下面的二维码,可以看到在线的d ...
- CSS3动画几个平时没注意的属性
一.timing-function: steps() 一开始在使用CSS3的时候并没有太注意这个timing-function,只是注意到自定义贝塞尔曲线. 1)一个项目中的实例 先来看看左边加了st ...
- 用CSS3动画特效实现弹窗效果
提示:如果大家觉得本篇实现的弹窗效果有用,可持续关注.接下会添加更多效果并且封装成插件,这样使用就方便了.效果查看: https://heavis.github.io/hidialog/index.h ...
- JavaScript - 基于CSS3动画的实现
在痛苦的IE8时代,所有的动画都只能基于自己计算相关动画属性,开定时器setTimeout/setInterval轮询动画任务. 而肩负重任的HTML5,早已注意到了日益增强的动画,随着HTML5的降 ...
- CSS3动画事件
CSS3 的动画效果强大,在移动端使用广泛,动画执行开始和结束都可以使用JS来监听其事件. animationstart animationend 以下是一个示例 <!DOCTYPE html& ...
- css3动画简介以及动画库animate.css的使用
在这个年代,你要是不懂一点点css3的知识,你都不好意思说你是个美工.美你妹啊,请叫我前端工程师好不好.呃..好吧,攻城尸...呵呵,作为一个攻城尸,没有点高端大气上档次的东西怎么能行呢,那么css3 ...
随机推荐
- HTTP响应状态码含义参考
1xx:信息 100 Continue服务器仅接收到部分请求,但是一旦服务器并没有拒绝该请求,客户端应该继续发送其余的请求.101 Switching Protocols服务器转换协议:服务器将遵从客 ...
- MyBatis 批量操作、集合遍历-foreach
在使用mybatis操作数据库时,经常会使用到批量插入.IN条件查询的情况,这时就难免要使用到foreach元素.下面一段话摘自mybatis官网: foreach 元素的功能是非常强大的,它允许你指 ...
- Spark Streaming VS Flink Streaming
引自:https://www.slideshare.net/datamantra/introduction-to-flink-streaming
- JDBC中rs.beforeFirst()
写在前面: 最近的项目比较老,用到了jdbc查询数据,展示数据.有时候一个查询语句的ResultSet需要用到好几次,即需要遍历好几次同一个查询结果集,那要怎么办呢? 使用如下方式即可解决 其实这里理 ...
- Python进阶之迭代器和生成器
可迭代对象 Python中任意的对象,只要它定义了可以返回一个迭代器的__iter__方法,或者定义了可以支持下标索引的__getitem__方法,那么它就是一个可迭代对象.简单来说,可迭代对象就是能 ...
- Solr集群搭建详细教程(二)
注:欢迎大家转载,非商业用途请在醒目位置注明本文链接和作者名dijia478,商业用途请联系本人dijia478@163.com. 之前步骤:Solr集群搭建详细教程(一) 三.solr集群搭建 注意 ...
- HTTP之URL分解
HTTP使用统一资源标识符(Uniform Resource Identifiers, URI)来传输数据和建立连接.URL是一种特殊类型的URI,包含了用于查找某个资源的足够的信息 URL,全称是U ...
- UVALive 4490 Help Bubu
题目大意:有n本书,高度值域为8,现可以把k本书拿出来再放进去,相邻的.高度相同的书算作一块,最小化块的个数.n=100. 强烈建议大家不要在做完区间DP后做别的DP题:区间DP是整体考虑,而一般DP ...
- Java解析word,获取文档中图片位置
前言(背景介绍): Apache POI是Apache基金会下一个开源的项目,用来处理office系列的文档,能够创建和解析word.excel.ppt格式的文档. 其中对word文档的处理有两个技术 ...
- glibc-commons 依赖解析 版本错误,xxx is duplicate yyy
glibc-commons 安装了两个版本,导致依赖glibc-commons的很多软件包 被安装了两个版本: 解决办法就是 先清除这些重复的已安装的软件,然后执行 yum update 将 glib ...