CSS实现简易边框动画

前言

这是一个简易的边框动画,实现原理很简单,通过css的hover属性,结合rotateX和rotateY实现。

效果

动画截图.png

html部分

html部分很简单,一个大盒子里面包着两个小盒子。

  

css部分

为了方便效果观看,我把body的背景色设置为黑色。大致思路为:最外层的div(也就是".border")给一个定位,为了美观,我把它通过fixed定位到了窗口的正中间。两个子div分别只有 上下边框 和 左右边框,都设置绝对定位,宽高和父元素相同,定位的位置为{left: 0; top: 0;},这是为了实现和父元素位置重合。两个div分别通过css3中的x轴和y轴(rotateX和rotateY)旋转90度,同时设置transition 时间。当鼠标滑过父元素的时候,两个div的旋转角度都归0。

    * {
      margin: 0;
      padding: 0;
    }
    html, body {
      background: #333;
    }
    .border {
      position: fixed;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      width: 200px;
      height: 200px;
      border: 1px solid #888;
      background: #444;
    }
    .border > div {
      position: absolute;
      left: -1px;
      top: -1px;
      width: 100%;
      height: 100%;
      transition: .5s;
    }
    .border:hover > .border-top-bottom{
      transform: rotateY(0);
    }
    .border:hover > .border-left-right{
      transform: rotateX(0);
    }
    .border-top-bottom {
      border: 1px solid transparent;
      border-top: 1px solid gold;
      border-bottom: 1px solid gold;
      transform: rotateY(90deg);
    }
    .border-left-right {
      border: 1px solid transparent;
      border-left: 1px solid gold;
      border-right: 1px solid gold;
      transform: rotateX(90deg);
    }

你可能感兴趣的:(CSS实现简易边框动画)