CSS 动画网格布局
在 CSS 网格中,您可以使用 grid-template-columns 和 grid-template-rows 属性分别定义线条名称,并跟踪网格列和行的大小。支持这些属性的插值可让网格布局在不同状态之间平滑过渡,而不是在动画或过渡的一半处贴靠。

CSS 中的值插值
在 CSS 中,您可以使用 transition 属性将属性从一个值平滑地转换为另一个值。
#target {
opacity: 0.5;
transition: opacity ease-in-out 0.25s;
}
#target:hover {
opacity: 1;
}
呈现引擎会自动检测目标属性的值的类型,并使用该信息平滑过渡到新值。
例如:
- 是否将
opacity从0转换为1? 这属于数字插值。 - 是否将
background-color从white转换为black? 在源颜色和目标颜色之间淡出。 - 要转换“
width”吗?通过数字插值方法,在整个过程中转换单位(如果需要)。
这同样适用于 CSS 动画,其中浏览器将在关键帧之间插入值。
为 grid-template-columns 和 grid-template-rows 添加动画效果
网格布局还可以顺畅地在不同状态之间切换,而不是在动画或过渡的一半处贴靠。
在下面的演示中,一个网格显示了多个头像。为了节省空间,头像使用 grid-template-columns 限制每个列的宽度,使头像堆叠在一起。将鼠标悬停在每列上时,它们将提供更多空间。
.avatars {
display: grid;
gap: 0.35em;
grid-auto-flow: column;
grid-template-columns: repeat(4, 2em);
transition: all ease-in-out 0.25s;
}
.avatars:hover {
grid-template-columns: repeat(4, 4em);
}
添加 transition 属性后,网格可以在值之间平滑地插值。
该效果也适用于更改 grid-template-columns 或 grid-template-rows 值的动画。