CSS3 中 transition 和 animation 的属性分别有哪些

Transition 属性:

​​transition​​ 属性用于定义元素在状态改变时从一个样式转换到另一个样式的过渡效果。它包含以下几个属性:

• ​​transition-property​​:指定过渡效果应用的 CSS 属性名称,多个属性可以用逗号分隔。

• ​​transition-duration​​:指定过渡效果的持续时间,单位可以是秒(s)或毫秒(ms)。

• ​​transition-timing-function​​:指定过渡效果的时间曲线,也就是过渡的速度变化函数。

• ​​transition-delay​​:指定过渡效果开始之前的延迟时间,单位可以是秒(s)或毫秒(ms)。

css 复制代码
/* 定义一个简单的过渡效果 */
.box {
  width: 100px;
  height: 100px;
  background-color: red;
  transition: width 1s ease-in-out;
}

.box:hover {
  width: 200px;
}

上面的示例中,当鼠标悬停在​​.box​​元素上时,宽度从100px过渡到 200px,过渡持续时间为 1 秒,过渡速度为 ease-in-out。

Animation 属性:

animation​​ 属性用于定义复杂的动画效果,可以自定义关键帧(keyframes)来实现更复杂的动画效果。它包含以下几个属性:

• ​​animation-name​​:指定定义动画的关键帧名称。

• ​​animation-duration​​:指定动画的持续时间,单位可以是秒(s)或毫秒(ms)。

• ​​animation-timing-function​​:指定动画的时间曲线,也就是动画的速度变化函数。

• ​​animation-delay​​:指定动画开始之前的延迟时间,单位可以是秒(s)或毫秒(ms)。

• ​​animation-iteration-count​​​:指定动画的重复次数,可以使用一个整数值或 ​​infinite​​(表示无限循环)。

• ​​animation-direction​​​:指定动画的播放方向,可以是 ​​normal​​​(默认),​​reverse​​​(反向播放),​​alternate​​​(正向再反向循环),或 ​​alternate-reverse​​(反向再正向循环)。

• ​​animation-fill-mode​​​:指定动画在非运行时的样式,可以是 ​​none​​​(默认),​​forwards​​​(保持最后一帧的样式),​​backwards​​​(应用第一帧的样式),或 ​​both​​(同时应用第一帧和最后一帧的样式)。

• ​​animation-play-state​​​:指定动画的播放状态,可以是 ​​running​​​(默认,动画正在播放)或 ​​paused​​(动画暂停)。

css 复制代码
/* 定义一个简单的动画 */
@keyframes slide-in {
  0% {
    transform: translateX(-100%);
  }
  100% {
    transform: translateX(0);
  }
}

.box {
  width: 100px;
  height: 100px;
  background-color: red;
  animation: slide-in 1s ease-in-out infinite alternate;
}

上面的示例中,​​.box​​ 元素会应用一个名为 ​​slide-in​​ 的动画,从左侧滑动进入容器,动画持续时间为 1 秒,以 ease-in-out 时间曲线播放,无限循环,并且往返运动。

相关推荐
英俊潇洒美少年4 分钟前
Vue3 中 watch的 flush 选项(默认无/`post`/`sync`)的区别
前端·javascript·vue.js
闲云一鹤6 分钟前
Python 入门(三)- PyAutoGUI 自动化教程
前端·python·黑客
凤山老林12 分钟前
Js如何实现一个抽奖程序
前端·javascript·vue.js
我命由我1234514 分钟前
React - Switch、路由精准匹配与模糊匹配、Redirect
开发语言·前端·javascript·react.js·前端框架·html·ecmascript
陆枫Larry20 分钟前
用 Git 别名(Alias)简化日常操作
前端
阿泽·黑核23 分钟前
Easy Vibe Coding 学习心得(三):前端之美——从设计稿到精美界面
前端·vibe coding·easy vibe
无心水33 分钟前
【时间利器】4、JavaScript时间处理全解:Date/moment/dayjs/Temporal
开发语言·前端·javascript·状态模式·openclaw·date/moment·dayjs/temporal
踩着两条虫38 分钟前
AI 驱动的 Vue3 应用开发平台 深入探究(二十五):API与参考之Renderer API 参考
前端·vue.js·人工智能
踩着两条虫38 分钟前
AI 驱动的 Vue3 应用开发平台 深入探究(二十四):API与参考之Provider API 参考
前端·vue.js·ai编程
恋猫de小郭44 分钟前
Android Studio Panda 2 ,支持 AI 用 Vibe Coding 创建项目
android·前端·flutter