0

0

关于CSS3元素中过渡属性transition的详细介绍

黄舟

黄舟

发布时间:2017-05-21 15:58:14

|

2670人浏览过

|

来源于php中文网

原创

过渡动画是动画的基础 

在学习动画属性之前
我们需要先了解过渡属性transition

过渡transition

先来看一个小例子

.demo {    width: 100px;    height: 100px;    background-color: royalblue;}.demo:hover {    width: 200px;}

这样当我的光标悬浮在demo的一瞬间
它的宽度变成了200px

有没有办法让我们光标悬浮在元素时,元素宽度缓慢变宽呢
在CSS3之前我们只能使用麻烦的js脚本
但是现在我们只需要添加一个属性
就可以达到我们的目的

.demo {    width: 100px;    height: 100px;    background-color: royalblue;    transition: width 1s; /*增*/}.demo:hover {    width: 200px;}

transition它的作用就是指定当你的元素某些样式发生变化时
这些样式可以渐渐过渡到最终属性值

立即学习前端免费学习笔记(深入)”;

它是一个复合属性
有以下子属性

  • transition-property:指定过渡或动态模拟的css属性

  • transition-duration:指定过渡所需要的时间

  • transition-timing-function:指定过渡函数

  • transition-delay:指定开始出现的延迟时间

transition-property 我们想要哪种属性过渡就写哪种属性
或者干脆写过渡所有属性的关键字all

transition-duration渐变时间属性值就是“数字+s”
代表几秒钟内过渡

transition-timing-function 是可选的属性值,有如下可选值

  • 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)

  • step-start
    等同 steps(1, start)

  • step-end
    等同 steps(1, end)

  • steps():
    两个参数的步进函数。第一个参数为正整数,指定函数步数。第二个参数取值是start或end,指定每一步的值发生变化的时间点。第二个参数可选,默认值为end。

  • cubic-bezier(num, num, num, num):
    特定的贝塞尔曲线类型,4个数值需在[0, 1]区间内

大多我们都用不上,最常用的大概就是我们默认的ease和线性过渡linear了

transition-delay 同样是可选属性值
如果你想要延迟过渡,换句话说如果我们想要在过渡前停一小会儿
那么就在这个复合属性的最后添加我们需要延迟的时间“数字+s”

这个属性可以对多个不同的属性进行设置
我们要做的就是使用逗号隔开

.demo {    width: 100px;    height: 100px;    background-color: royalblue;    transition: width 1s linear, 
                height 1s linear,
                background-color 2s 1s; /*改*/}.demo:hover {    width: 200px;    height: 200px;    background-color: lawngreen; /*改*/}

鼠标移出元素后,元素又过渡回来

易可图
易可图

电商人都在用的设计平台

下载

使用过渡属性而不是脚本的另一个原因是
脚本方法改变多个元素样式可能会产生冲突
解决的办法是使用bool变量加锁,还是很麻烦
我们的transition过渡属性就不需要考虑这么多
元素与元素之间互不影响


还有一点要注意,元素过渡需要知道样式具体的起始属性和末尾属性
比如说我们例子中的width明确了从100px过渡到200px

.demo:hover {    width: auto; /*改*/
    height: 200px;    background-color: lawngreen; /*改*/}

改变了悬浮样式width为auto
我们发现当光标悬浮元素后
width属性并没有发生过渡

参与过渡的属性

当然也不是所有的样式都可以过渡
比如说你想让 display:block 过渡到 display:inline-block
那是不可能的
有以下属性参与过渡

  • color

  • visibility

  • opacity

  • vertical-align

  • z-index

  • clip

  • width/height

  • top/bottom/left/right

  • background-color/position

  • border-top/bottom/left/right-color/width

  • border/letter/word-spacing

  • font-size/weight

  • line-height

  • margin/padding-top/bottom/left/right

  • max/min-height/width

  • outline-color/width

  • text-indent/shadow

可以看到这个属性真的是十分强大

相关专题

更多
c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

42

2026.01.23

c++空格相关教程合集
c++空格相关教程合集

本专题整合了c++空格相关教程,阅读专题下面的文章了解更多详细内容。

46

2026.01.23

yy漫画官方登录入口地址合集
yy漫画官方登录入口地址合集

本专题整合了yy漫画入口相关合集,阅读专题下面的文章了解更多详细内容。

202

2026.01.23

漫蛙最新入口地址汇总2026
漫蛙最新入口地址汇总2026

本专题整合了漫蛙最新入口地址大全,阅读专题下面的文章了解更多详细内容。

341

2026.01.23

C++ 高级模板编程与元编程
C++ 高级模板编程与元编程

本专题深入讲解 C++ 中的高级模板编程与元编程技术,涵盖模板特化、SFINAE、模板递归、类型萃取、编译时常量与计算、C++17 的折叠表达式与变长模板参数等。通过多个实际示例,帮助开发者掌握 如何利用 C++ 模板机制编写高效、可扩展的通用代码,并提升代码的灵活性与性能。

16

2026.01.23

php远程文件教程合集
php远程文件教程合集

本专题整合了php远程文件相关教程,阅读专题下面的文章了解更多详细内容。

100

2026.01.22

PHP后端开发相关内容汇总
PHP后端开发相关内容汇总

本专题整合了PHP后端开发相关内容,阅读专题下面的文章了解更多详细内容。

73

2026.01.22

php会话教程合集
php会话教程合集

本专题整合了php会话教程相关合集,阅读专题下面的文章了解更多详细内容。

75

2026.01.22

宝塔PHP8.4相关教程汇总
宝塔PHP8.4相关教程汇总

本专题整合了宝塔PHP8.4相关教程,阅读专题下面的文章了解更多详细内容。

67

2026.01.22

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
CSS3 教程
CSS3 教程

共18课时 | 4.8万人学习

HTML5/CSS3/JavaScript/ES6入门课程
HTML5/CSS3/JavaScript/ES6入门课程

共102课时 | 6.8万人学习

HTML+CSS基础与实战
HTML+CSS基础与实战

共132课时 | 9.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号