转换

CSS 播客 - 第 044 集:转场

与网站互动时,您可能会注意到许多元素都有状态。例如,下拉菜单可以处于打开或关闭状态。按钮在聚焦或悬停时可能会更改颜色。模态窗口会出现和消失。

默认情况下,CSS 会立即切换这些状态的样式。

使用 CSS 转场效果,我们可以在元素的初始状态和目标状态之间进行插值。这两者之间的转换可提供视觉指示、支持,并提示互动的原因和影响,从而提升用户体验。

过渡属性

Browser Support

  • Chrome: 26.
  • Edge: 12.
  • Firefox: 16.
  • Safari: 9.

Source

如需在 CSS 中使用转场效果,您可以使用各种转场属性或 transition 缩写属性。

transition-property

transition-property 属性用于指定要转换的样式。

.my-element {
  transition-property: background-color;
}

transition-property 接受以英文逗号分隔的列表中的一个或多个 CSS 属性名称。

您也可以选择使用 transition-property: all 指明每个属性都应进行转换。

transition-duration

transition-duration 属性用于定义转换完成所需的时间长度。

transition-duration 接受以秒 (s) 或毫秒 (ms) 为单位的时间,默认值为 0s

transition-timing-function

使用 transition-timing-function 属性可在 transition-duration 期间调整 CSS 转换的速度。

默认情况下,CSS 会以恒定的速度 (transition-timing-function: linear) 对元素进行转换。不过,线性转换最终可能会看起来有些不自然:在现实生活中,物体有重量,无法立即停止和启动。缓慢进入或退出过渡可以让过渡效果更生动、更自然。

我们的 CSS 动画模块对时间函数进行了详细介绍。

您可以使用 DevTools 实时试用不同的计时函数。

Chrome DevTools 中的视觉转换时间编辑器。

transition-delay

使用 transition-delay 属性指定转换的开始时间。如果未指定 transition-delay,则过渡将立即开始,因为默认值为 0s。此属性接受时间单位,例如秒 (s) 或毫秒 (ms)。

此属性对于错开转场效果非常有用,只需为组中的每个后续元素设置更长的 transition-delay 即可实现。

transition-delay 在调试时也很有用。将延迟设置为负值可让过渡在时间轴上更晚开始。

简写形式:transition

与大多数 CSS 属性一样,它也有一个简写版本。transition 会组合使用 transition-propertytransition-durationtransition-timing-functiontransition-delay

.longhand {
  transition-property: transform;
  transition-duration: 300ms;
  transition-timing-function: ease-in-out;
  transition-delay: 0s;
}

.shorthand {
  transition: transform 300ms ease-in-out 0s;
}

哪些内容可以转移,哪些内容无法转移?

编写 CSS 时,您可以指定哪些属性应具有动画转换效果。请参阅 MDN 上可呈现动画效果的 CSS 属性列表

一般来说,只有在元素的起始状态和最终状态之间存在“中间状态”时,才能对其进行转换。例如,无法为 font-family 添加转场效果,因为无法确定 serifmonospace 之间的“中间状态”应如何显示。另一方面,可以为 font-size 添加转场效果,因为它的单位是可在之间插值的长度。

形状从一种状态平滑过渡到另一种状态的示意图,以及两行采用不同字体的文本,它们无法平滑过渡。

以下是您可以转换的一些常见媒体资源。

转换

Browser Support

  • Chrome: 36.
  • Edge: 12.
  • Firefox: 16.
  • Safari: 9.

Source

transform CSS 属性通常会进行转换,因为它是 GPU 加速属性,可产生更流畅的动画,同时也能降低电池用量。借助此属性,您可以任意缩放、旋转、平移或扭曲元素。

请参阅“Functions”模块中的“转换”部分

颜色

在互动之前、期间和之后,颜色都可以很好地指示状态。例如,如果用户将鼠标悬停在某个按钮上,该按钮可能会更改颜色。这种颜色变化可以向用户提供按钮可点击的反馈。

colorbackground-colorborder-color 属性只是在互动时可以转换颜色的几个位置之一。

请参阅有关颜色的模块

阴影

阴影通常会进行转换,以指示高度变化,例如从用户聚焦。

请参阅有关阴影的模块

过滤条件

filter 是一项强大的 CSS 属性,可让您动态添加图形效果。在不同的 filter 状态之间转换可以产生一些非常出色的效果。

请参阅有关过滤条件的模块

转换触发器

您的 CSS 必须包含状态更改触发该状态更改的事件,CSS 转场才能激活。:hover 伪类就是此类触发器的一个典型示例。当用户将光标悬停在元素上时,此伪类会匹配。

下面列出了一些可触发元素状态变化的伪类和事件。

  • :hover:如果游标位于元素上,则匹配。
  • :focus:如果元素获得焦点,则匹配。
  • :focus-within:如果元素或其任何子元素获得焦点,则匹配。
  • :target:当当前网址的片段与元素的 ID 匹配时匹配。
  • :active:在元素被激活时匹配(通常是在鼠标按下该元素时)。
  • 通过 JavaScript 进行 class 更改:当元素的 CSS class 通过 JavaScript 发生更改时,CSS 将转换已更改的符合条件的属性。

进入或退出时采用不同的转换

通过在悬停/聚焦时设置不同的 transition 属性,可以创建一些有趣的效果。

.my-element {
  background: red;

  /* This transition is applied on the "exit" transition */
  transition: background 2000ms ease-in;
}

.my-element:hover {
  background: blue;

  /* This transition is applied on the "enter" transition */
  transition: background 150ms ease;
}

无障碍功能注意事项

CSS 转场效果并非人人皆宜。某些用户可能会因过渡效果和动画而产生晕动或不适感。幸运的是,CSS 有一个名为 prefers-reduced-motion 的媒体功能,可检测用户是否已表明希望设备减少动画效果。

/*
  If the user has expressed their preference for
  reduced motion, then don't use transitions.
*/
@media (prefers-reduced-motion: reduce) {
  .my-element {
    transition: none;
  }
}

/*
  If the browser understands the media query and the user
  explicitly hasn't set a preference, then use transitions.
*/
@media (prefers-reduced-motion: no-preference) {
  .my-element {
    transition: transform 250ms ease;
  }
}

如需详细了解此媒体功能,请参阅我们的博文 prefers-reduced-motion:有时动作越少越好

性能考虑因素

使用 CSS 转场效果时,如果您为某些 CSS 属性添加转场效果,可能会遇到性能问题。例如,当 widthheight 等属性发生变化时,它们会将内容推送到网页的其余部分。这会强制 CSS 为过渡的每个帧计算每个受影响元素的新位置。我们建议您尽可能改用 transformopacity 等属性。

如需深入了解此主题,请参阅我们的有关高性能 CSS 动画的指南

检查您的理解情况

测试您对转场效果的了解程度

哪个转换属性用于指定缓动?

transition-duration
请重试。
transition-easing
不是真正的 CSS 属性。
transition-cubic-bezier
不是真正的 CSS 属性。
transition-timing-function
正确!
animation-ease
不是真正的 CSS 属性。

最佳实践是使用 transition-property: all

true
请重试。指定 all 可能会导致性能问题和意外转换。
false
正确。最佳做法是单独指定每个房源。更精细的控制可带来更好的效果和更可预测的结果。

所有媒体资源都可以转换。

true
请重试。font-family 等属性无法转换。
false
正确。您可以为不兼容的属性指定转换,但它们的转换将是离散的。