zoukankan      html  css  js  c++  java
  • 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{
           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;
        }
      }
    }

  • 相关阅读:
    各种文件的mime类型
    LeetCode_122. Best Time to Buy and Sell Stock II
    LeetCode_121. Best Time to Buy and Sell Stock
    LeetCode_119. Pascal's Triangle II
    LeetCode_118. Pascal's Triangle
    LeetCode_112. Path Sum
    LeetCode_111. Minimum Depth of Binary Tree
    LeetCode_110. Balanced Binary Tree
    LeetCode_108. Convert Sorted Array to Binary Search Tree
    LeetCode_107. Binary Tree Level Order Traversal II
  • 原文地址:https://www.cnblogs.com/rogerwu/p/9585730.html
Copyright © 2011-2022 走看看