transition(过渡)和animation(动画)——CSS

1.transition过渡

可以为一个元素在不同状态之间进行切换时添加过渡效果,实现不同状态间的变化效果。通过触发事件(鼠标悬停、点击等),在两个状态间切换。

1.1 使用

语法:transition: [property] [duration] [timing-function] [delay];

  • property​ ​:过渡属性(如background-colorall表示所有属性)。

  • ​duration​ ​:持续时间(如0.3s),必须设置

  • ​timing-function​ ​:速度曲线(easelinearcubic-bezier()等)。

  • ​delay​ ​:延迟时间(如0.2s

示例代码:表示当鼠标悬停在img标签时,宽高从200×200变为500×400。

html 复制代码
<style>
    img {
        width:200px;
        height:200px;
        
        transition:all 1s;
        /*all表示对自身所有属性都加上过渡效果,若要单独让某个属性添加过渡则写具体的css属性,1s表示过渡效果的时间*/
    }
    img:hover {
        width:500px;
        height:400px;
    }
</style>

<img src="#">

2. animation动画

通过关键帧定义复杂动画序列,支持自动播放和循环,允许在复数个状态间进行切换,且可以在页面加载时自动开始运行,不需要事件触发。

2.1 使用

语法:animation: [name] [duration] [timing-function] [delay] [iteration-count] [direction] [fill-mode];

  • ​name​ ​:@keyframes定义的动画名。

  • ​iteration-count​ ​:播放次数(infinite为无限循环)。

  • ​direction​ ​:播放方向(alternate交替播放)。

  • ​fill-mode​ ​:动画结束状态(forwards保留最后一帧)。

代码示例:修改box盒子的background-color属性,从红色变为黄色。

html 复制代码
<style>
	@keyframes example {
 /* from(等价于 0%):动画起始状态;to(等价于 100%):动画结束状态,可通过百分比定义中间状态(如 50% {background-color: blue;} */
  		from {background-color: red;}
  		to {background-color: yellow;}
}

.box {
  width: 100px;
  height: 100px;
  background-color: red;
    /* 引用关键帧,过渡时间为5s, infinite为动画无限循环 */
  animation: example 5s infinite;
}
</style>
相关推荐
喝拿铁写前端20 小时前
前端开发者使用 AI 的能力层级——从表面使用到工程化能力的真正分水岭
前端·人工智能·程序员
wuhen_n20 小时前
LeetCode -- 15. 三数之和(中等)
前端·javascript·算法·leetcode
七月shi人21 小时前
AI浪潮下,前端路在何方
前端·人工智能·ai编程
非凡ghost21 小时前
MusicPlayer2(本地音乐播放器)
前端·windows·学习·软件需求
脾气有点小暴21 小时前
scroll-view分页加载
前端·javascript·uni-app
beckyye21 小时前
ant design vue Table根据数据合并单元格
前端·antd
布列瑟农的星空21 小时前
还在手动翻译国际化词条?AST解析+AI翻译实现一键替换
前端·后端·ai编程
土豆125021 小时前
Rust 错误处理完全指南:从入门到精通
前端·rust·编程语言
QT 小鲜肉1 天前
【Linux命令大全】001.文件管理之mmove命令(实操篇)
linux·服务器·前端·chrome·笔记