最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:懂视网 责编:小采 时间:2020-11-27 18:51:37
文档

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

关于CSS3元素中过渡属性transition的详细介绍:过渡动画是动画的基础 在学习动画属性之前 我们需要先了解过渡属性transition过渡transition先来看一个小例子<p class="demo"></p>.demo { width: 100px; height: 100px; background-color: r
推荐度:
导读关于CSS3元素中过渡属性transition的详细介绍:过渡动画是动画的基础 在学习动画属性之前 我们需要先了解过渡属性transition过渡transition先来看一个小例子<p class="demo"></p>.demo { width: 100px; height: 100px; background-color: r

过渡动画是动画的基础

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

过渡transition

先来看一个小例子

<p class="demo"></p>
.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

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

    声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文档

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

    关于CSS3元素中过渡属性transition的详细介绍:过渡动画是动画的基础 在学习动画属性之前 我们需要先了解过渡属性transition过渡transition先来看一个小例子<p class="demo"></p>.demo { width: 100px; height: 100px; background-color: r
    推荐度:
    • 热门焦点

    最新推荐

    猜你喜欢

    热门推荐

    专题
    Top