transition-delay

Baseline 已广泛支持

此特性已相当成熟,可在许多设备和浏览器版本上使用。自 2015 年 9 月以来,该特性已在各大浏览器中可用。

transition-delay CSS 属性指定了当属性值发生变化时,在开始属性的过渡效果之前等待的时间。

试一试

transition-delay: 250ms;
transition-property: margin-right;
transition-delay: 1s;
transition-property: background-color;
transition-delay: 1s;
transition-property: margin-right, color;
transition-delay: 1s, 250ms;
transition-property: margin-right, color;
<section id="default-example">
  <div id="example-element">Hover to see<br />the transition.</div>
</section>
#example-element {
  background-color: #e4f0f5;
  color: black;
  padding: 1rem;
  border-radius: 0.5rem;
  font: 1em monospace;
  width: 100%;
  transition: margin-right 2s;
}

#default-example:hover > #example-element {
  background-color: #990099;
  color: white;
  margin-right: 40%;
}

延迟可以是零、正数或负数。

  • 0s(或 0ms)将立即开始过渡效果。
  • 正值将使过渡效果的开始延迟给定的时间长度。
  • 负值将立即开始过渡效果,并从效果的中间开始。换句话说,效果将如同已经运行了给定的时间长度一样进行动画。

您可以指定多个延迟,这在对多个属性进行过渡时很有用。每个延迟将应用于由 transition-property 属性指定(作为主列表)的相应属性。如果指定的延迟少于主列表中的延迟,则延迟值列表将重复,直到足够。如果延迟多于属性,则延迟值列表将被截断以匹配属性的数量。在这两种情况下,CSS 声明仍然有效。

语法

css
/* <time> values */
transition-delay: 3s;
transition-delay: 2s, 4ms;

/* Global values */
transition-delay: inherit;
transition-delay: initial;
transition-delay: revert;
transition-delay: revert-layer;
transition-delay: unset;

<time>

表示属性值更改与过渡效果开始之间等待的时间量。

正式定义

初始值0s
应用于所有元素,::before::after 伪元素
继承性
计算值同指定值
动画类型不可动画化

正式语法

transition-delay = 
<time>#
此语法反映了根据 CSS 过渡的最新标准。并非所有浏览器都可能实现了所有部分。有关支持信息,请参阅浏览器兼容性

示例

显示不同延迟的示例

HTML

html
<div class="box delay-1">0.5 seconds</div>

<div class="box delay-2">2 seconds</div>

<div class="box delay-3">4 seconds</div>

<button id="change">Change</button>

CSS

css
.box {
  margin: 20px;
  padding: 10px;
  display: inline-block;
  width: 100px;
  height: 100px;
  background-color: red;
  font-size: 18px;
  transition-property: background-color, font-size, transform, color;
  transition-timing-function: ease-in-out;
  transition-duration: 3s;
}

.transformed-state {
  transform: rotate(270deg);
  background-color: blue;
  color: yellow;
  font-size: 12px;
  transition-property: background-color, font-size, transform, color;
  transition-timing-function: ease-in-out;
  transition-duration: 3s;
}

.delay-1 {
  transition-delay: 0.5s;
}

.delay-2 {
  transition-delay: 2s;
}

.delay-3 {
  transition-delay: 4s;
}

JavaScript

js
function change() {
  const elements = document.querySelectorAll("div.box");
  for (const element of elements) {
    element.classList.toggle("transformed-state");
  }
}

const changeButton = document.querySelector("#change");
changeButton.addEventListener("click", change);

结果

规范

规范
CSS 过渡
# transition-delay-property

浏览器兼容性

另见