CSS中的 `transition` 属性是用于添加过渡效果的属性,它在两个状态的元素间提供一个平滑的过渡效果。当改变一个元素的状态时(如颜色、大小等),可以通过 `transition` 属性实现平滑的过渡效果,而不是立即切换。这使得页面看起来更加自然和流畅。
`transition` 属性是一个简写属性,用于设置四个属性的值:
1. `transition-property`: 指定应用过渡效果的 CSS 属性名称。例如,`width` 或 `background-color` 等。
2. `transition-duration`: 定义过渡效果的持续时间。默认值是 `0`,意味着没有过渡效果。你可以指定具体的时间值,如 `2s` 或 `120ms`。
3. `transition-timing-function`: 定义过渡效果的速度曲线。默认值是 `linear`,意味着从开始到结束保持相同的速度。其他的可选值包括 `ease`, `ease-in`, `ease-out`, 和 `ease-in-out` 等。
4. `transition-delay`: 定义过渡效果何时开始。默认值是 `0`,意味着过渡效果立即开始。你可以指定一个正值来延迟过渡效果的开始时间。
使用示例:
```css
/* 为元素的宽度和背景颜色添加过渡效果 */
div {
transition: width 2s ease-in-out, background-color 1s linear;
}
```
此外,还有一个重要的概念是“连续的属性值”(如颜色和背景图像)。在这种情况下,应使用逗号分隔每个属性及其对应的值,例如:`transition: background 2s ease, color 1s ease-in;`。这表示背景属性会在两秒内平滑过渡,而颜色属性会在一秒内平滑过渡并呈现进入效果。如果不为每个属性提供单独的持续时间或定时函数,它们将使用第一个指定的值。如果省略某些值(如只指定持续时间而不指定定时函数),它们将采用默认值(线性函数)。