it编程 > 网页制作 > Css

CSS3动态效果之过渡属性(最新推荐)

33人参与 2025-02-19 Css

过渡——css3动态效果 过渡属性

一、什么是过渡:

二、过渡属性:

过渡有四个属性:transition-property 、transition-duration 、transition-timing-function 、transition-delay

1、transition-property

定义:

此属性可以设置添加过渡的 css 样式,可以单独设置只有某一个 css 属性具有过渡效果(property),也可以设置所有属性都有过渡效果(all)

属性:

transition-property 有三个属性值:none、all、property

.box {
    width: 200px;
    height: 200px;
    background-color: blue;
    transition-property: width,height;
}
.box:hover {
    width: 300px;
    height: 300px;
    background-color: red;
}

此时宽和高会获得过渡效果,但是背景颜色不会获得过渡效果。因为我们的 transition-property 里面没有添加属性值 background-color 。

2、transition-duration 定义;

此属性表示规定完成过渡效果需要多少秒或毫秒

属性值:

transition-duration 只有一个属性值:time。表示完成过渡效果需要花费的时间(以秒s或毫秒ms计算,默认为0,意味着没有效果)

有了这个属性,上面的案例效果就可以展现出来了。

.box {
    width: 200px;
    height: 200px;
    background-color: blue;
    transition-property: width, height;
    transition-duration: 2s;
}
.box:hover {
    width: 300px;
    height: 300px;
    background-color: red;
}

此时将鼠标放在我们的蓝色盒子上,他的宽高会用2s变大,但是背景颜色会瞬间变大,因为我们并没有给背景颜色添加过渡效果。

3、transition-timing-function 定义:

此属性规定了过渡效果的速度,默认值为ease 。

属性值:

transition-timing-function 有五个属性值:linear、ease、ease-in、ease-out、ease-in-out

.box {
    width: 200px;
    height: 200px;
    background-color: blue;
    transition-property: width, height;
    transition-duration: 2s;
    transition-timing-function: linear;
}
.box:hover {
    width: 300px;
    height: 300px;
    background-color: red;
}

在 transition-duration 的案例中,我们可以感受到那时的过渡变换过程是慢速开始、中间匀速、再慢速结束,因为那时我们没有设置 transition-timing-function 的属性值,他默认为 ease 。此时我们将他设置为 linear ,我们可以感受到,此时他是全程匀速的。其他的属性值,大家也自己尝试一下,感受感受他们的不同吧。

4、transition-delay 定义:

此属性定义:何时将开始过渡效果,也叫过渡延迟时间。

属性值:

与 transition-duration 一样,transition-delay 也只有一个属性值:time。规定在过渡效果开始之前需要等待的时间(以秒s或毫秒ms计算),默认为0,即立即开始过渡效果。

.box {
    width: 200px;
    height: 200px;
    background-color: blue;
    transition-property: width, height;
    transition-duration: 2s;
    transition-timing-function: linear;
    transition-delay: 2s;
}
.box:hover {
    width: 300px;
    height: 300px;
    background-color: red;
}

此案例中,蓝色盒子会立即变成红色盒子,但是会静止2s,然后再用2s匀速变大到宽高都为300px。那静止的2s即为 transition-delay 设定的属性值。

三、过渡的简写

transition: [transition-property] [transition-duration] [transition-timing-function] [transition-delay];

按照上面的顺序,列出属性值即可,属性值中间用空格分开。

所以我们的最后一个案例也可以写成:

.box {
    width: 200px;
    height: 200px;
    background-color: blue;
    transition: all 2s linear 2s;
}
.box:hover {
    width: 300px;
    height: 300px;
    background-color: red;
}

注意:此时的 transition-property 需要设置为 all 或者只设置一个值(width\height\backgroud-color),设置为 all 时,width、height、background-color都具有过渡效果,设置单个属性值时,其他两个属性值就不具有过渡效果,会立即变化。不可以将 transition-property 写成 width,height,即:

.box {
    width: 200px;
    height: 200px;
    background-color: blue;
    transition: width,height 2s linear 2s;
}
.box:hover {
    width: 300px;
    height: 300px;
    background-color: red;
}

此时的 width 将不具有过渡效果,会立即变为 300px 。只有 height 会延迟2s ,然后花费 2s 变为 300px ,再停顿 2s 后,花费 2s 变回 200px 。

到此这篇关于css3动态效果 过渡属性的文章就介绍到这了,更多相关css3动态效果内容请搜索代码网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持代码网!

(0)
打赏 微信扫一扫 微信扫一扫

您想发表意见!!点此发布评论

推荐阅读

css3 实现icon刷新转动效果

02-19

CSS3实现动态旋转加载样式的示例代码

02-19

css3 display:flex 弹性盒模型的使用方法

02-19

巧用 CSS 实现高频出现的复杂怪状按钮之镂空的内凹圆角边框(示例代码)

02-18

CSS3模拟实现一个雷达探测扫描动画特效(最新推荐)

02-21

css实现渐变色圆角边框

02-17

猜你喜欢

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论