前言
W3C标准中对css3的transition这是样描述的:“css的transition允许css的属性值在一定的时间区间内平滑地过渡。这种效果可以在鼠标单击、获得焦点、被点击或对元素任何改变中触发,并圆滑地以动画效果改变CSS的属性值。”
过渡transition
先来看一个小例子
<div class="demo"></div>
.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
可以看到这个属性真的是十分强大
总结
以上就是这篇文章的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]