CSS3 Transition

transition (过渡) 属性:允许 css 的属性值在一定的时间区间内平滑地过渡。这种效果可以在鼠标单击、获得焦点、被点击或对元素任何改变中触发,并圆滑地以动画效果改变css的值

 transition : [<'transition-property'> || <'transition-duration'> || <'transition-timing-function'> || <'transition-delay'> [, [<'transition-property'> || <'transition-duration'> || <'transition-timing-function'> || <'transition-delay'>]]* 

transition 主要包含以下四个属性:

1、transition-property 执行过渡的属性

用来指定当元素其中一个属性改变时,执行 transition 效果。主要有以下几个值:

none:没有属性改变。为 none时,transition 马上停止执行

all:所有属性改变(默认值)。为 all 时,元素产生任何属性值变化时都将执行 transition 效果

indent:元素属性名 (如:width,color,background-color,vertical-align,top,left,border-width 等)

 

2、transition-duration 过渡延续的时间

transition-duration : <time> [, <time>]* 

用来指定元素过渡过程的持续时间,取值为数值,单位为s 或 ms。默认值是 0

可以作用于所有元素,包括 :before 和 :after 伪元素

 

3、transition-timing-function 在延续时间段,过渡的速率变化

transition-timing-function : ease | linear | ease-in | ease-out | ease-in-out | cubic-bezier(<number>, <number>, <number>, <number>) [, ease | linear | ease-in | ease-out | ease-in-out | cubic-bezier(<number>, <number>, <number>, <number>)]* 

允许你根据时间的推进去改变属性值的过渡速率,有6个取值

ease 逐渐变慢 默认值。规定慢速开始,然后变快,然后慢速结束的过渡效果(cubic-bezier(0.25,0.1,0.25,1))
linear 匀速 规定以相同速度开始至结束的过渡效果(等于 cubic-bezier(0,0,1,1))
ease-in 加速   规定以慢速开始的过渡效果(等于 cubic-bezier(0.42,0,1,1))
ease-out 减速 规定以慢速结束的过渡效果(等于 cubic-bezier(0,0,0.58,1))
ease-in-out 加速然后减速 规定以慢速开始和结束的过渡效果(等于 cubic-bezier(0.42,0,0.58,1))
cubic-bezier(x1, y1, x2, y2) 自定义一个时间曲线 在 cubic-bezier 函数中定义自己的值。(x1,y1,x2,y2) 四个值特定于曲线上点P1(x1,y1) 和 点P2(x2,y2)。所有值须在[0,1]区域内,否则无效

 

 

 

 

 

 

 

4、transition-delay 过渡延迟时间

transition-duration : <time> [, <time>]* 

用来指定一个动画开始执行的时间,也就是说当改变元素属性值后多长时间开始执行 transition 效果。

取值为数值,单位为 s 或 ms,默认值是 0,也就是过渡立即执行,没有延迟

 

简写语法:

div {
    transition: <property> <duration> <timing-function> <delay>;
}

DEMO 1: 多个属性一起过渡

<div class="demo1">
      <p>盒子的多个属性一起动画: width, height, background-color, transform. 将光标悬停在盒子上查看动画。</p>
      <div class="box"></div>
</div>
.demo1{
  .box{
    width: 100px;
    height: 100px;
    border: 1px solid #ccc;
    background-color: #0000FF;
    -webkit-transition: width 2s, height 2s, background-color 2s, -webkit-transform 2s;
    -moz-transition: width 2s, height 2s, background-color 2s, -moz-transform 2s;
    -o-transition: width 2s, height 2s, background-color 2s, -o-transform 2s;
    transition: width 2s, height 2s, background-color 2s, transform 2s;
    &:hover{
      width: 200px;
      height: 200px;
      background-color: #ffcccc;
      -webkit-transform: rotate(180deg);
      -moz-transform: rotate(180deg);
      -o-transform: rotate(180deg);
      -ms-transform: rotate(180deg);
      transform: rotate(180deg);
    }
  }
}

DEMO 2: 4s 过渡改变字体大小,2s 延迟 

<div class="demo2">show me transition!</div>
.demo2{
  position: relative;
  font-size: 14px;
  -webkit-transition: font-size 4s 2s;
  -moz-transition: font-size 4s 2s;
  -o-transition: font-size 4s 2s;
  transition: font-size 4s 2s;
  &:hover{
    font-size: 36px;
    -webkit-transition: font-size 4s 2s;
    -moz-transition: font-size 4s 2s;
    -o-transition: font-size 4s 2s;
    transition: font-size 4s 2s;
  }
}

DEMO 3: 高亮菜单过渡效果

<div class="demo3">
      <div class="sidebar">
        <p><a class="menuButton" href="home">Home</a></p>
        <p><a class="menuButton" href="about">About</a></p>
        <p><a class="menuButton" href="contact">Contact Us</a></p>
        <p><a class="menuButton" href="links">Links</a></p>
      </div>
</div>
.sidebar{
  display: flex;
  >p:not(:last-child){
    margin-right: 15px;
  }
  .menuButton{
    height: 26px;
    padding: 2px 4px;
    box-shadow: 2px 2px 1px solid;
    border: 1px solid #000;
    font-size: 20px;
    text-align: center;
    text-decoration: none;
    color: #fff;
    background-color: #666;
    -webkit-transition: color 1s ease-out, background-color 1s ease-out;
    -moz-transition: color 1s ease-out, background-color 1s ease-out;
    -o-transition: color 1s ease-out, background-color 1s ease-out;
    transition: color 1s ease-out, background-color 1s ease-out;
    &:hover{
      color: #000;
      background-color: #fff;
      -webkit-transition: color 1s ease-out, background-color 1s ease-out;
      -moz-transition: color 1s ease-out, background-color 1s ease-out;
      -o-transition: color 1s ease-out, background-color 1s ease-out;
      transition: color 1s ease-out, background-color 1s ease-out;
    }
  }
}

posted @ 2018-09-04 17:21  rogerwu  阅读(316)  评论(0编辑  收藏  举报