目录
过渡效果(transition)
在css3中发布了三种新添加的特性,可以让静止的网站变得动起来,而且不需要借助js脚本就能实现。
这便是其中的一种,过渡。
transition-duration
transition-duration 属性规定完成过渡效果需要花费的时间。
<style>
div {
width: 100px;
height: 100px;
background: lightblue;
transition-property: width;
transition-duration: 5s;
}
div:hover {
width: 333px;
}
</style>
<body>
<div></div>
<p>将鼠标移动至块上即可看到过渡动画效果.</p>
<p><b>注意:</b> 该过渡效果会持续5s.</p>
</body>
过渡经常和:hover一起使用,效果为:
transition-property
transition-property 属性规定应用过渡效果的 CSS 属性的名称。
<style>
div
{
width:100px;
height:100px;
background:green;
transition-duration:3s;
transition-property:width,height,background-color;
}
div:hover
{
width:333px;
height: 222px;
background-color: #2ebb96;
}
</style>
<body>
<div></div>
<p>将鼠标移动至块上即可看到过渡动画效果.</p>
<p><b>注意:</b> 该过渡效果会持续3s.指定的width,height,background-color会发生改变</p>
</body>
效果为
transition-delay
transition-delay 属性指定何时将开始切换效果。
<style>
div
{
width:100px;
height:100px;
background:green;
transition-duration:3s;
transition-property:width,height,background-color;
transition-delay: 1s;
}
div:hover
{
width:333px;
height: 222px;
background-color: #2ebb96;
}
</style>
<body>
<div></div>
<p>将鼠标移动至块上即可看到过渡动画效果.</p>
<p><b>注意:</b> 该过渡效果会持续3s.指定的width,height,background-color会发生改变</p>
</body>
效果为
transition-timing-function
transition-timing-function属性指定切换效果的速度。
该属性使用贝塞尔曲线来设置,css提供了一些特定的效果,当然也可以自己自定义贝塞尔曲线函数。
- linear: 线性过渡。等同于贝塞尔曲线(0.0, 0.0, 1.0, 1.0)
- ease:默认值,平滑过渡。等同于贝塞尔曲线(0.25, 0.1, 0.25, 1.0)
- ease-in:由慢到快。等同于贝塞尔曲线(0.42, 0, 1.0, 1.0)
- ease-out: 由快到慢。等同于贝塞尔曲线(0, 0,0.58, 1.0)
- ease-in-out: 由慢到快再到慢。等同于贝塞尔曲线(0.42, 0, 0.58, 1.0)
- cubic-bezier(, , , ):特定的贝塞尔曲线类型,4个数值需在[0, 1]区间内
然后我自定义了一个贝塞尔曲线cubic-bezier(0.71,1.8,1,-0.74);
<style>
div
{
width:100px;
height:50px;
background:green;
color:white;
font-weight:bold;
transition:width 3s;
margin-bottom: 10px;
}
#div1 {transition-timing-function: linear;}
#div2 {transition-timing-function: ease;}
#div3 {transition-timing-function: ease-in;}
#div4 {transition-timing-function: ease-out;}
#div5 {transition-timing-function: ease-in-out;}
#div6 {transition-timing-function: cubic-bezier(0.71,1.8,1,-0.74);}
div:hover
{
width:333px;
}
</style>
<body>
<p>将鼠标移至相应块上即可查看过渡动画.</p>
<div id="div1" style="top:100px">linear</div>
<div id="div2" style="top:150px">ease</div>
<div id="div3" style="top:200px">ease-in</div>
<div id="div4" style="top:250px">ease-out</div>
<div id="div5" style="top:300px">ease-in-out</div>
<div id="div6" style="top:300px">我的自定义</div>
</body>
效果:
transition
transition同样可以缩小
transition:[ transition-property ] || [ transition-duration ] ||
[ transition-timing-function ] || [ transition-delay ];
变形(transition)
transform属性应用于元素的2D或3D转换。
指定相应的变形函数就能达到相应的效果。
旋转函数rotate
rotate(angle):旋转,参数angle表示要旋转的角度值。如果角度为正数值,则按照顺时针进行旋转, 否则,按照逆时针旋转。
- rotate(angle) 定义 2D 旋转,在参数中规定角度。
- rotateX(angle) 定义沿着 X 轴的 3D 旋转。
- rotateY(angle) 定义沿着 Y 轴的 3D 旋转。
- rotateZ(angle) 定义沿着 Z 轴的 3D 旋转。
- rotate3d(x,y,z,angle) 定义 3D 旋转。
<style>
div
{
display: inline-block;
margin: 30px;
font-size: 14px;
text-align: center;
line-height: 150px;
width:150px;
height:150px;
background:lightskyblue;
color:white;
transition:all 3s;
margin-bottom: 10px;
}
#div1:hover {transform: rotate(360deg);}
#div2:hover {transform: rotate(-360deg);}
#div3:hover {transform: rotateX(360deg);}
#div4:hover {transform: rotateY(360deg);}
#div5:hover {transform: rotateZ(360deg);}
#div6:hover {transform: rotate3D(1,1,1,180deg);}
</style>
<body>
<p>将鼠标移至相应块上即可查看过渡动画.</p>
<p>这是2D的旋转</p>
<div id="div1" >rotate(360deg)</div>
<div id="div2" >rotate(-360deg)</div>
<br>
<p>这是3D的旋转</p>
<div id="div3" >rotateX(360deg)</div>
<div id="div4" >rotateY(360deg)</div>
<div id="div5" >rotateZ(360deg)</div>
<div id="div6" >rotate3D(1,1,1,180deg)</div>
</body>
为了效果上的直观,所以添加了过渡属性,让方块的改变更加清晰。
效果为:
移动translate
- translate(x,y) 定义 2D 转换。
- translateX(x) 定义转换,只是用 X 轴的值。
- translateY(y) 定义转换,只是用 Y 轴的值。
- translateZ(z) 定义 3D 转换,只是用 Z 轴的值。
- translate3d(x,y,z) 定义 3D 转换。
这是2D的移动
<style>
div
{
display: inline-block;
margin: 30px;
font-size: 14px;
text-align: center;
line-height: 150px;
width:150px;
height:150px;
background:lightskyblue;
color:white;
transition:all 3s;
margin-bottom: 10px;
}
#div1:hover {transform: translateX(200px);}
#div2:hover {transform: translateY(200px);}
#div3:hover {transform: translate(200px,200px);}
</style>
<body>
<p>将鼠标移至相应块上即可查看过渡动画.</p>
<p>这是2D的移动</p>
<div id="div1" >X轴移动:translateX</div>
<div id="div2" >Y轴移动:translateY</div>
<br>
<div id="div3" >XY轴移动:translate</div>
<br>
</body>
效果为:
缩放scale
- scaleX(x) 通过设置 X 轴的值来定义缩放转换。
- scaleY(y) 通过设置 Y 轴的值来定义缩放转换。
- scaleZ(z) 通过设置 Z 轴的值来定义 3D 缩放转换。
- scale(x[,y]?) 定义 2D 缩放转换。
- scale3d(x,y,z) 定义 3D 缩放转换。
2D方向的缩放
<style>
div
{
display: inline-block;
margin: 30px;
font-size: 14px;
text-align: center;
line-height: 150px;
width:150px;
height:150px;
background:lightskyblue;
color:white;
transition:all 3s;
margin-bottom: 10px;
margin-left: 50px;
}
#div1:hover {transform: scaleX(1.5);}
#div2:hover {transform: scaleY(0.5);}
#div3:hover {transform: scale(1.5,.5);}
</style>
<body>
<p>将鼠标移至相应块上即可查看过渡动画.</p>
<p>这是2D的缩放</p>
<div id="div1" >X轴放大:scaleX(1.5)</div>
<div id="div2" >Y轴缩小:scaleY(0.5)</div>
<br>
<div id="div3" >XY轴缩放:scale(1.5,.5)</div>
</body>
效果为:
倾斜skew
- skew(x-angle,y-angle) 定义沿着 X 和 Y 轴的 2D 倾斜转换。
- skewX(angle) 定义沿着 X 轴的 2D 倾斜转换。
- skewY(angle) 定义沿着 Y 轴的 2D 倾斜转换。
<style>
div
{
display: inline-block;
margin: 30px;
font-size: 14px;
text-align: center;
line-height: 150px;
width:150px;
height:150px;
background:lightskyblue;
color:white;
transition:all 3s;
margin-bottom: 10px;
margin-left: 50px;
}
#div1:hover {transform: skewX(45deg);}
#div2:hover {transform: skewY(45deg);}
#div3:hover {transform: skew(15deg,30deg);}
</style>
<body>
<p>将鼠标移至相应块上即可查看过渡动画.</p>
<p>这是2D的缩放</p>
<div id="div1" >X轴倾斜45度:skewX(45deg)</div>
<div id="div2" >Y轴倾斜45度:skewY(45deg)</div>
<br>
<div id="div3" >XY轴倾斜:skew(15deg,30deg)</div>
</body>
效果为: