使用纯 CSS 创作一个渐变色动画边框

  

使用纯 CSS 创作一个渐变色动画边框,通常需要遵循以下步骤:

Step 1:创建 HTML 元素

首先,在 HTML 中创建一个元素,该元素将作为动画边框的容器,如下所示:

<div class="border-container"></div>

Step 2:添加样式

接下来,在 CSS 中添加一些样式,为动画边框创建一些基础样式,如下所示:

.border-container {
  width: 200px;
  height: 200px;
  border: 5px solid transparent;
}

在上面的代码中,.border-container 是创建的容器类名,这里设置的宽度、高度和边框的颜色都是可以根据实际需要进行调整的。

Step 3:添加动画

接下来,使用 CSS 动画添加动态效果,以实现渐变色动画边框:

.border-container {
  width: 200px;
  height: 200px;
  border: 5px solid transparent;
  animation: animate-border 2s ease infinite;
}

@keyframes animate-border {
  from {
    border-image-slice: 1;
    border-color: #e91e63;
  }
  to {
    border-image-slice: 2;
    border-color: #2196f3;
  }
}

在上面的代码中,通过 border-image-sliceborder-color 属性来定义渐变效果,并使用 animation 属性添加动画。其中 animate-border 是用来定义动画效果的名称,2s 表示动画持续时间为 2 秒钟,ease 表示动画的过渡效果,infinite 表示动画持续时间为无限循环(可以用数字代替表示动画循环次数)。

示例说明1

.border-container{
  height: 100px;
  width: 150px;
  border: 5px solid transparent;
  animation: animate-border 2s ease infinite;
}

@keyframes animate-border {
  0%{
      border-image-slice: 1;
      border-color: rgba(5, 249, 247, 0.473);
  }
  50%{
      border-image-slice: 2;
      border-color: rgba(234, 2, 123, 0.825);
  }
  100%{
      border-image-slice: 3;
      border-color: rgba(255, 255, 255);
  }
}

在示例说明 1 中,将 border-image-slice 的属性值在 0% 时设置为 1,在 50% 时设置为 2,在 100% 时设置为 3,在颜色值中使用了 rgba 来设置透明度。

示例说明2

.border-container {
  height: 100px;
  width: 150px;
  border: 5px solid transparent;
  animation: animate-border 2s ease infinite;
}

@keyframes animate-border {
  0% {
    border-image-slice: 1;
    border-color: #fcf876;
  }
  40% {
    border-image-slice: 2;
    border-color: #33dc8b;
  }
  80% {
    border-image-slice: 3;
    border-color: #5bc0de;
  }
  100% {
    border-image-slice: 4;
    border-color: #d9534f;
  }
}

在示例说明 2 中,将进度设置为多个时间点的变化,在不同时候改变边界值和颜色值。

以上便是使用纯 CSS 创作渐变色动画边框的完整攻略。

相关文章