• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    六种css3实现的边框过渡效果

    六种效果

    实现代码

    html

    <h1>CSS Border Transitions</h1>
    
    <section class="buttons">
      <button class="draw">Draw</button>
    
      <button class="draw meet">Draw Meet</button>
    
      <button class="center">Center</button>
    
      <button class="spin">Spin</button>
    
      <button class="spin circle">Spin Circle</button>
    
      <button class="spin thick">Spin Thick</button>
    </section>

    css3

    button {
      background: none;
      border: 0;
      box-sizing: border-box;
      margin: 1em;
      padding: 1em 2em;
      box-shadow: inset 0 0 0 2px #f45e61;
      color: #f45e61;
      font-size: inherit;
      font-weight: 700;
      position: relative;
      vertical-align: middle;
    }
    button::before, button::after {
      box-sizing: inherit;
      content: "";
      position: absolute;
      width: 100%;
      height: 100%;
    }
    
    .draw {
      transition: color 0.25s;
    }
    .draw::before, .draw::after {
      border: 2px solid transparent;
      width: 0;
      height: 0;
    }
    .draw::before {
      top: 0;
      left: 0;
    }
    .draw::after {
      bottom: 0;
      right: 0;
    }
    .draw:hover {
      color: #60daaa;
    }
    .draw:hover::before, .draw:hover::after {
      width: 100%;
      height: 100%;
    }
    .draw:hover::before {
      border-top-color: #60daaa;
      border-right-color: #60daaa;
      transition: width 0.25s ease-out, height 0.25s ease-out 0.25s;
    }
    .draw:hover::after {
      border-bottom-color: #60daaa;
      border-left-color: #60daaa;
      transition: border-color 0s ease-out 0.5s, width 0.25s ease-out 0.5s, height 0.25s ease-out 0.75s;
    }
    
    .meet:hover {
      color: #fbca67;
    }
    .meet::after {
      top: 0;
      left: 0;
    }
    .meet:hover::before {
      border-top-color: #fbca67;
      border-right-color: #fbca67;
    }
    .meet:hover::after {
      border-bottom-color: #fbca67;
      border-left-color: #fbca67;
      transition: height 0.25s ease-out, width 0.25s ease-out 0.25s;
    }
    
    .center:hover {
      color: #6477b9;
    }
    .center::before, .center::after {
      top: 0;
      left: 0;
      height: 100%;
      width: 100%;
      transform-origin: center;
    }
    .center::before {
      border-top: 2px solid #6477b9;
      border-bottom: 2px solid #6477b9;
      transform: scale3d(0, 1, 1);
    }
    .center::after {
      border-left: 2px solid #6477b9;
      border-right: 2px solid #6477b9;
      transform: scale3d(1, 0, 1);
    }
    .center:hover::before, .center:hover::after {
      transform: scale3d(1, 1, 1);
      transition: transform 0.5s;
    }
    
    .spin {
      width: 5em;
      height: 5em;
      padding: 0;
    }
    .spin:hover {
      color: #0eb7da;
    }
    .spin::before, .spin::after {
      top: 0;
      left: 0;
    }
    .spin::before {
      border: 2px solid transparent;
    }
    .spin:hover::before {
      border-top-color: #0eb7da;
      border-right-color: #0eb7da;
      border-bottom-color: #0eb7da;
      transition: border-top-color 0.15s linear, border-right-color 0.15s linear 0.1s, border-bottom-color 0.15s linear 0.2s;
    }
    .spin::after {
      border: 0 solid transparent;
    }
    .spin:hover::after {
      border-top: 2px solid #0eb7da;
      border-left-width: 2px;
      border-right-width: 2px;
      transform: rotate(270deg);
      transition: transform 0.4s linear 0s, border-left-width 0s linear 0.35s;
    }
    
    .circle {
      border-radius: 100%;
      box-shadow: none;
    }
    .circle::before, .circle::after {
      border-radius: 100%;
    }
    
    .thick {
      color: #f45e61;
    }
    .thick:hover {
      color: #fff;
      font-weight: 700;
    }
    .thick::before {
      border: 2.5em solid transparent;
      z-index: -1;
    }
    .thick::after {
      mix-blend-mode: color-dodge;
      z-index: -1;
    }
    .thick:hover::before {
      background: #f45e61;
      border-top-color: #f45e61;
      border-right-color: #f45e61;
      border-bottom-color: #f45e61;
      transition: background 0s linear 0.4s, border-top-color 0.15s linear, border-right-color 0.15s linear 0.15s, border-bottom-color 0.15s linear 0.25s;
    }
    .thick:hover::after {
      border-top: 2.5em solid #f45e61;
      border-left-width: 2.5em;
      border-right-width: 2.5em;
    }
    
    /* Page styling */
    html {
      background: #fefefe;
    }
    
    body {
      background: #fefefe;
      color: #4b507a;
      font: 300 24px/1.5 Lato, sans-serif;
      margin: 1em auto;
      max-width: 36em;
      padding: 1em 1em 2em;
      text-align: center;
    }
    
    .buttons {
      isolation: isolate;
    }
    
    h1 {
      font-weight: 300;
      font-size: 2.5em;
    }

    以上就是六种css3实现的边框过渡效果的详细内容,更多关于CSS3 边框过渡的资料请关注脚本之家其它相关文章!

    上一篇:CSS3 实现的动态星空背景
    下一篇:position:sticky 粘性定位的几种巧妙应用详解
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    六种css3实现的边框过渡效果 六种,css3,实现,的,边框,