CSS3 过渡
优质
小牛编辑
139浏览
2023-12-01
.animated_div { width:60px; height:40px; background:#92B901; color:#ffffff; position:absolute; font-weight:bold; font-size:15px; padding:10px; float:left; margin:5px; -webkit-transition:-webkit-transform 1s,opacity 1s,background 1s,width 1s,height 1s,font-size 1s; -webkit-border-radius:5px; -o-transition-property:width,height,-o-transform,background,font-size,opacity; -o-transition-duration:1s,1s,1s,1s,1s,1s; -moz-transition-property:width,height,-o-transform,background,font-size,opacity; -moz-transition-duration:1s,1s,1s,1s,1s,1s; transition-property:width,height,transform,background,font-size,opacity; transition-duration:1s,1s,1s,1s,1s,1s; border-radius:5px; opacity:0.4; } .animated_div:hover { -moz-transform: rotate(360deg); -webkit-transform: rotate(360deg); -o-transform: rotate(360deg); transform: rotate(360deg); opacity:1; background:#1ec7e6; width:90px; height:60px; font-size:30px; }
过渡
data:image/s3,"s3://crabby-images/fd6c1/fd6c19c1ce4bb98331a44f084c2f05155da4b759" alt="Opera Opera"
data:image/s3,"s3://crabby-images/f4ddf/f4ddf7ef5092915fc76997226d93712d7682405a" alt="Safari Safari"
data:image/s3,"s3://crabby-images/85a7c/85a7c0f54c69b3ad397e7cd994e54d0302c665f4" alt="Chrome Chrome"
data:image/s3,"s3://crabby-images/d783e/d783e9d412ca5f4bd000fb87d657c5973aa6898f" alt="Firefox Firefox"
data:image/s3,"s3://crabby-images/9b679/9b679436a17494687bbb15744edbdef96558e72a" alt="Internet Explorer Internet Explorer"
data:image/s3,"s3://crabby-images/7e31a/7e31ad7db373941f0c0f1a7c0a1c86fc4522c73f" alt="Opera Opera"
data:image/s3,"s3://crabby-images/606cd/606cd419cca2bcb220dce9a3a1957333fb4db170" alt="Safari Safari"
data:image/s3,"s3://crabby-images/e0329/e03291eaf4f9bcf57d93641c20778b1bc71a639a" alt="Chrome Chrome"
data:image/s3,"s3://crabby-images/50a30/50a30373f6b3bd09f8ce7166de8b56af832c31dc" alt="Firefox Firefox"
data:image/s3,"s3://crabby-images/e57ff/e57ffa6ac013266a5d6be9d48ae57d2e76a565be" alt="Internet Explorer Internet Explorer"
data:image/s3,"s3://crabby-images/20d3c/20d3ccce6ce1f23a215cf60b1eb6ab2a171b0eb4" alt="Opera Opera"
data:image/s3,"s3://crabby-images/cb9cb/cb9cb3e7791c32d8c517eb9c86446d9625c1aae8" alt="Safari Safari"
data:image/s3,"s3://crabby-images/add25/add25cbdb0d2553bc7c2f149caab3da33d32fdac" alt="Chrome Chrome"
data:image/s3,"s3://crabby-images/1b265/1b265fd380023c469dbbb8fb13993079e3dae481" alt="Firefox Firefox"
data:image/s3,"s3://crabby-images/107ab/107abc504a9661335e4a08d06df98cd9256d30c7" alt="Internet Explorer Internet Explorer"
CSS3 过渡
CSS3中,我们为了添加某种效果可以从一种样式转变到另一个的时候,无需使用Flash动画或JavaScript。用鼠标移过下面的元素:
用鼠标移过下面的元素:
CSS3过渡
浏览器支持
表格中的数字表示支持该属性的第一个浏览器版本号。
紧跟在 -webkit-, -ms- 或 -moz- 前的数字为支持该前缀属性的第一个浏览器版本号。
属性 | |||||
---|---|---|---|---|---|
transition | 26.0 4.0 -webkit- | 10.0 | 16.0 4.0 -moz- | 6.1 3.1 -webkit- | 12.1 10.5 -o- |
transition-delay | 26.0 4.0 -webkit- | 10.0 | 16.0 4.0 -moz- | 6.1 3.1 -webkit- | 12.1 10.5 -o- |
transition-duration | 26.0 4.0 -webkit- | 10.0 | 16.0 4.0 -moz- | 6.1 3.1 -webkit- | 12.1 10.5 -o- |
transition-property | 26.0 4.0 -webkit- | 10.0 | 16.0 4.0 -moz- | 6.1 3.1 -webkit- | 12.1 10.5 -o- |
transition-timing-function | 26.0 4.0 -webkit- | 10.0 | 16.0 4.0 -moz- | 6.1 3.1 -webkit- | 12.1 10.5 -o- |
它是如何工作?
CSS3 过渡是元素从一种样式逐渐改变为另一种的效果。
要实现这一点,必须规定两项内容:
- 指定要添加效果的CSS属性
- 指定效果的持续时间。
data:image/s3,"s3://crabby-images/fd6c1/fd6c19c1ce4bb98331a44f084c2f05155da4b759" alt="Opera Opera"
data:image/s3,"s3://crabby-images/f4ddf/f4ddf7ef5092915fc76997226d93712d7682405a" alt="Safari Safari"
data:image/s3,"s3://crabby-images/85a7c/85a7c0f54c69b3ad397e7cd994e54d0302c665f4" alt="Chrome Chrome"
data:image/s3,"s3://crabby-images/d783e/d783e9d412ca5f4bd000fb87d657c5973aa6898f" alt="Firefox Firefox"
data:image/s3,"s3://crabby-images/9b679/9b679436a17494687bbb15744edbdef96558e72a" alt="Internet Explorer Internet Explorer"
应用于宽度属性的过渡效果,时长为 2 秒:
div { transition: width 2s; -webkit-transition: width 2s; /* Safari */ }注意: 如果未指定的期限,transition将没有任何效果,因为默认值是0。
指定的CSS属性的值更改时效果会发生变化。一个典型CSS属性的变化是用户鼠标放在一个元素上时:
data:image/s3,"s3://crabby-images/7e31a/7e31ad7db373941f0c0f1a7c0a1c86fc4522c73f" alt="Opera Opera"
data:image/s3,"s3://crabby-images/606cd/606cd419cca2bcb220dce9a3a1957333fb4db170" alt="Safari Safari"
data:image/s3,"s3://crabby-images/e0329/e03291eaf4f9bcf57d93641c20778b1bc71a639a" alt="Chrome Chrome"
data:image/s3,"s3://crabby-images/50a30/50a30373f6b3bd09f8ce7166de8b56af832c31dc" alt="Firefox Firefox"
data:image/s3,"s3://crabby-images/e57ff/e57ffa6ac013266a5d6be9d48ae57d2e76a565be" alt="Internet Explorer Internet Explorer"
规定当鼠标指针悬浮(:hover)于 <div>元素上时:
div:hover { width:300px; }注意: 当鼠标光标移动到该元素时,它逐渐改变它原有样式
多项改变
要添加多个样式的变换效果,添加的属性由逗号分隔:
data:image/s3,"s3://crabby-images/20d3c/20d3ccce6ce1f23a215cf60b1eb6ab2a171b0eb4" alt="Opera Opera"
data:image/s3,"s3://crabby-images/cb9cb/cb9cb3e7791c32d8c517eb9c86446d9625c1aae8" alt="Safari Safari"
data:image/s3,"s3://crabby-images/add25/add25cbdb0d2553bc7c2f149caab3da33d32fdac" alt="Chrome Chrome"
data:image/s3,"s3://crabby-images/1b265/1b265fd380023c469dbbb8fb13993079e3dae481" alt="Firefox Firefox"
data:image/s3,"s3://crabby-images/107ab/107abc504a9661335e4a08d06df98cd9256d30c7" alt="Internet Explorer Internet Explorer"
添加了宽度,高度和转换效果:
div { transition: width 2s, height 2s, transform 2s; -webkit-transition: width 2s, height 2s, -webkit-transform 2s; }过渡属性
下表列出了所有的过渡属性:
属性 | 描述 | CSS |
---|---|---|
![]() ![]() ![]() ![]() ![]() 与上面的例子相同的过渡效果,但是使用了简写的 transition 属性: div { transition: width 1s linear 2s; /* Safari */ -webkit-transition:width 1s linear 2s; } |