CSS线性渐变进度动画

时间:2020-03-27 21:28:16

标签: css css-animations linear-gradients

我整理了一个动画,该动画指示倒数,直到吐司通知消失:

.toastDiv {
  animation: toastProgress 3s ease;
  border: 1px solid rgba(0, 0, 0, .5);
  border-radius: 5px;
  box-shadow: 0 0 5px 0 rgba(0, 0, 0, .25);
  margin: 0 0 1ex 0;
  padding: 1ex 1em;
}

@keyframes toastProgress {
  0% {
    background: linear-gradient(to right, aliceblue 0%, aliceblue 0%, white 0%, white 100%);
  }
  10% {
    background: linear-gradient(to right, aliceblue 0%, aliceblue 10%, white 10%, white 100%);
  }
  20% {
    background: linear-gradient(to right, aliceblue 0%, aliceblue 20%, white 20%, white 100%);
  }
  30% {
    background: linear-gradient(to right, aliceblue 0%, aliceblue 30%, white 30%, white 100%);
  }
  40% {
    background: linear-gradient(to right, aliceblue 0%, aliceblue 40%, white 40%, white 100%);
  }
  50% {
    background: linear-gradient(to right, aliceblue 0%, aliceblue 50%, white 50%, white 100%);
  }
  60% {
    background: linear-gradient(to right, aliceblue 0%, aliceblue 60%, white 60%, white 100%);
  }
  70% {
    background: linear-gradient(to right, aliceblue 0%, aliceblue 70%, white 70%, white 100%);
  }
  80% {
    background: linear-gradient(to right, aliceblue 0%, aliceblue 80%, white 80%, white 100%);
  }
  90% {
    background: linear-gradient(to right, aliceblue 0%, aliceblue 90%, white 90%, white 100%);
  }
  100% {
    background: linear-gradient(to right, aliceblue 0%, aliceblue 100%, white 100%, white 100%);
  }
}
<div class="toastDiv">hello</div>

但是,必须拼出各个动画阶段非常繁琐,按照我选择的粒度,我得到的结果不稳定。

我尝试使用这个:

@keyframes toastProgress {
  from {
    background: linear-gradient(to right, aliceblue 0%, aliceblue 0%, white 0%, white 100%);
  }
  to {
    background: linear-gradient(to right, aliceblue 0%, aliceblue 100%, white 100%, white 100%);
  }
}

但是,这是从一个纯色背景过渡到另一个纯色背景,而不是从左到右为颜色设置动画。

是否有一种方法可以仅使用fromto而不使用百分比步长来制作这种进度样式的渐变动画?

1 个答案:

答案 0 :(得分:2)

您可以像下面这样依靠background-size动画和steps()

.toastDiv {
  border: 1px solid rgba(0, 0, 0, .5);
  border-radius: 5px;
  box-shadow: 0 0 5px 0 rgba(0, 0, 0, .25);
  margin: 0 0 1ex 0;
  padding: 1ex 1em;
  background:
    linear-gradient(aliceblue,aliceblue) left no-repeat,
    white;
  animation: toastProgress 5s steps(10,start); 
}

@keyframes toastProgress {
  0% {
    background-size:0% 100%;
  }
  100% {
    background-size:100% 100%;
  }
}
<div class="toastDiv">hello</div>

<div class="toastDiv" style="animation-timing-function:ease">without Steps</div>

有关了解steps()的工作原理:https://stackoverflow.com/a/51843473/8620333

相关问题