1. 过渡
过渡(transition)
- 通过过渡可以指定一个属性发生变化时的切换方式
- 通过过渡可以创建一些非常好的效果,提升用户的体验
1.1 transition-property: 指定要执行过渡的属性
多个属性间使用,隔开
如果所有属性都需要过渡,则使用all关键字
大部分属性都支持过渡效果,注意过渡时必须是从一个有效数值向另外一个有效数值进行过渡(auto不是有效数值,过渡动画效果不会生效)
1.2 transition-duration: 指定过渡效果的持续时间
时间单位:s 和 ms 1s = 1000ms
1.3 transition-timing-function: 过渡的时序函数
指定过渡的执行的方式
可选值:
-
ease 默认值,慢速开始,先加速,再减速
-
linear 匀速运动
-
ease-in 加速运动
-
ease-out 减速运动
-
ease-in-out 先加速 后减速
-
cubic-bezier() 来指定时序函数
https://cubic-bezier.com -
steps() 分步执行过渡效果
可以设置一个第二个值:(填写数字表示 几步完成)
- end , 在时间结束时执行过渡(默认值)
- start , 在时间开始时执行过渡
1.4 transition-delay: 过渡效果的延迟,等待一段时间后在执行过渡
transition-delay: 2s;
1.5 transition
可以同时设置过渡相关的所有属性,只有一个要求,如果要写延迟,则两个时间中第一个是持续时间,第二个是延迟
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
<style>
*{
margin: 0;
padding: 0;
}
.box1{
width: 800px;
height: 800px;
background-color: silver;
overflow: hidden;
}
.box1 div{
width: 100px;
height: 100px;
margin-bottom: 100px;
margin-left: 0;
}
.box2{
background-color: #bfa;
/* margin-left: auto; */
/* transition:all 2s; */
/*
过渡(transition)
- 通过过渡可以指定一个属性发生变化时的切换方式
- 通过过渡可以创建一些非常好的效果,提升用户的体验
*/
/*
transition-property: 指定要执行过渡的属性
多个属性间使用,隔开
如果所有属性都需要过渡,则使用all关键字
大部分属性都支持过渡效果,注意过渡时必须是从一个有效数值向另外一个有效数值进行过渡
*/
/* transition-property: height , width; */
/* transition-property: all; */
/*
transition-duration: 指定过渡效果的持续时间
时间单位:s 和 ms 1s = 1000ms
*/
/* transition-duration: 100ms, 2s; */
/* transition-duration: 2s; */
/*
transition-timing-function: 过渡的时序函数
指定过渡的执行的方式
可选值:
ease 默认值,慢速开始,先加速,再减速
linear 匀速运动
ease-in 加速运动
ease-out 减速运动
ease-in-out 先加速 后减速
cubic-bezier() 来指定时序函数
https://cubic-bezier.com
steps() 分步执行过渡效果
可以设置一个第二个值:
end , 在时间结束时执行过渡(默认值)
start , 在时间开始时执行过渡
*/
/* transition-timing-function: cubic-bezier(.24,.95,.82,-0.88); */
/* transition-timing-function: steps(2, start); */
/*
transition-delay: 过渡效果的延迟,等待一段时间后在执行过渡
*/
/* transition-delay: 2s; */
/* transition 可以同时设置过渡相关的所有属性,只有一个要求,如果要写延迟,则两个时间中第一个是持续时间,第二个是延迟 */
transition:2s margin-left 1s cubic-bezier(.24,.95,.82,-0.88);
}
.box3{
background-color: orange;
transition-property: all;
transition-duration: 2s;
}
.box1:hover div{
/* width: 200px;
height: 200px; */
/* background-color: orange; */
margin-left: 700px;
}
</style>
</head>
<body>
<div class="box1">
<div class="box2"></div>
<div class="box3"></div>
</div>
</body>
</html>
2. 动画
动画和过渡类似,都是可以实现一些动态的效果,不同的是过渡需要在某个属性发生变化时才会触发, 动画可以自动触发动态效果。
2.1 设置动画效果,必须先要设置一个关键帧,关键帧设置了动画执行每一个步骤。
关键帧语法:
@keyframes test {
/* from表示动画的开始位置 也可以使用 0% */
from{
margin-left: 0;
background-color: orange;
}/* to动画的结束位置 也可以使用100%*/
to{
background-color: red;
margin-left: 700px;
}
2.2 设置动画到相应的元素上
animation-name: 要对当前元素生效的关键帧的名字
animation-name: test;
2.3 animation-duration: 设置动画的执行时间
animation-duration: 4s;
2.4 animation-delay: 设置动画的延时
animation-delay: 2s;
2.5 animation-timing-function: 运动的状态
2.6 animation-iteration-count 动画执行的次数
可选值:
- 次数(数字)
- infinite 无限执行
2.7 animation-direction: 指定动画运行的方向
可选值:
- normal 默认值 从 from 向 to运行 每次都是这样
- reverse 从 to 向 from 运行 每次都是这样
- alternate 从 from 向 to运行 重复执行动画时反向执行
- alternate-reverse 从 to 向 from运行 重复执行动画时反向执行
2.8 animation-play-state: 设置动画的执行状态
可选值:
- running 默认值 动画执行
- paused 动画暂停
2.9 animation-fill-mode: 设置动画的填充模式
可选值:
- none 默认值 动画执行完毕元素回到原来位置
- forwards 动画执行完毕元素会停止在动画结束的位置
- backwards 动画延时等待时,元素就会处于开始位置
- both 结合了forwards 和 backwards
2.10 简写
animation: test 2s 2 1s alternate; 和transition 的简写类似 ,执行时间和延时时间顺序注意
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset