CSS3中的元素过渡属性transition示例详解

所属分类: 网页制作 / CSS 阅读数: 1241
收藏 0 赞 0 分享

前言

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

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

总结

以上就是这篇文章的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。

更多精彩内容其他人还在看

利用纯CSS3实现动态的自行车特效源码

这篇文章主要介绍了如何利用纯CSS3实现动态的自行车的方法,文中给出了完整的实例代码,实现后的效果非常不错,大家可以直接运行看看效果,需要的朋友下面来一起学习学习吧。
收藏 0 赞 0 分享

web前端开发规范文档(2014年版本)

这篇文章主要为大家介绍了前端开发团队遵循和约定的代码书写规范,意在提高代码的规范性和可维护性,需要的朋友可以参考下
收藏 0 赞 0 分享

前端编码规范(4)—— CSS 和 Sass (SCSS) 开发规范

这篇文章主要介绍了前端编码规范(4)—— CSS 和 Sass (SCSS) 开发规范,需要的朋友可以参考下
收藏 0 赞 0 分享

手把手教你用CSS实现带箭头的流程进度条

这篇文章主要给大家介绍了利用CSS实现带箭头的流程进度条大方法,文中给出了详细的示例代码,对大家具有一定的参考价值,有需要的朋友们一起来看看吧。
收藏 0 赞 0 分享

CSS实现三栏布局的四种方法示例

可能有人不理解三栏布局是什么,其实三栏布局页面分为左中右三部分,然后对中间一部分做自适应的一种布局方式,下面这篇文章就给大家详细介绍了CSS实现三栏布局的四种方法,需要的朋友可以参考借鉴,下面来一起看看吧。
收藏 0 赞 0 分享

利用css实现浮雕效果示例代码

这篇文章主要给大家介绍了利用css如何实现浮雕的效果,文中给出了详细的示例代码和解释,相信对大家有一定的参考价值,感兴趣的朋友们下面来一起看看吧。
收藏 0 赞 0 分享

浏览器默认样式(User Agent Stylesheet)的介绍与最佳处理方法

这篇文章主要给大家介绍了浏览器默认样式(User Agent Stylesheet)的相关资料,并给出了相对应的最佳解决方法。有需要的朋友可以参考借鉴,下面来一起看看吧。
收藏 0 赞 0 分享

css中px、em和rem的区别总结

相信每位前端工程师们都有这么一个体会,国内的设计师大都喜欢用px,而国外的网站大都喜欢用em和rem,那么三者有什么区别,又各自有什么优劣呢?下面这篇文章小编就来给大家详细介绍关于css中px、em和rem的区别,需要的朋友可以参考借鉴,下面来一起看看吧。
收藏 0 赞 0 分享

CSS3实现点击放大的动画实例代码

这篇文章主要给大家介绍了关于利用CSS3实现点击放大的动画效果,文中给出了完整的实例代码,相信对大家具有一定的参考价值,需要的朋友们可以一起来看看吧。
收藏 0 赞 0 分享

利用css代码实现纸飞机效果实例源码

这篇文章主要给大家介绍了如何利用css代码实现纸飞机的效果,实现后效果非常不错,文中给出了详细的实例代码,大家可以参考借鉴,下面来一起看看吧。
收藏 0 赞 0 分享
查看更多