《CSS 简易速速上手小册》第5章:CSS 动画与过渡(2024 最新版)

在这里插入图片描述

文章目录

  • 5.1 CSS 过渡基础:网页的微妙舞步
    • 5.1.1 基础知识
    • 5.1.2 重点案例:按钮悬停效果
    • 5.1.3 拓展案例 1:渐变显示导航菜单
    • 5.1.4 拓展案例 2:动态调整元素大小
  • 5.2 关键帧动画:编排你的网页芭蕾
    • 5.2.1 基础知识
    • 5.2.2 重点案例:呼吸效果的背景色变化
    • 5.2.3 拓展案例 1:滚动显示的文字
    • 5.2.4 拓展案例 2:旋转进入的图标
  • 5.3 实用动画案例分析:优雅地迈出每一步
    • 5.3.1 基础知识
    • 5.3.2 重点案例:页面加载动画
    • 5.3.3 拓展案例 1:滚动触发的动画
    • 5.3.4 拓展案例 2:数据仪表板的动态图表

5.1 CSS 过渡基础:网页的微妙舞步

当网页元素轻盈地在状态之间跳跃,那一刻,它们不再是静态的代码块,而是充满生命的舞者。CSS过渡赋予了它们这种能力,让它们在变化中展现出流畅的美感。理解CSS过渡的基础,就是学会编排这场精彩的舞蹈。

5.1.1 基础知识

  • 过渡属性(Transition Property):指定哪个CSS属性将应用过渡效果。可以是具体的属性名,或使用 all 应用于所有可过渡的属性。
  • 过渡时长(Transition Duration):定义过渡效果从开始到结束的时间长度,通常以秒(s)或毫秒(ms)为单位。
  • 过渡曲线(Transition Timing Function):控制过渡的速度曲线,例如 linearease-inease-outease-in-out
  • 过渡延迟(Transition Delay):设置过渡效果开始前的延迟时间。

5.1.2 重点案例:按钮悬停效果

设计一个按钮,当鼠标悬停时,背景颜色和文字颜色平滑过渡,提升用户交互体验。

  • HTML 结构
<button class="transition-button">悬停我</button>
  • CSS 样式
.transition-button {
  background-color: #007BFF;
  color: white;
  padding: 10px 20px;
  border: none;
  transition: background-color 0.5s ease-in-out, color 0.5s ease-in-out;
}

.transition-button:hover {
  background-color: #0056b3;
  color: #ffcc00;
}

通过设置 transition 属性,我们创建了一个平滑的颜色过渡效果,让按钮在鼠标悬停时更加动感和吸引人。

5.1.3 拓展案例 1:渐变显示导航菜单

假设你的网站有一个隐藏的导航菜单,当用户点击菜单按钮时,希望菜单能够以渐变的方式显示出来。

  • HTML 结构
<nav class="hidden-menu">菜单内容</nav>
  • CSS 样式
.hidden-menu {
  opacity: 0;
  transition: opacity 0.5s ease-in-out;
}

.hidden-menu.visible {
  opacity: 1;
}

通过切换 .hidden-menu 元素的 .visible 类,我们可以实现菜单的渐变显示和隐藏效果。

5.1.4 拓展案例 2:动态调整元素大小

让一个元素在鼠标悬停时动态地改变大小,增加页面的互动性。

  • HTML 结构
<div class="resize-box">悬停改变大小</div>
  • CSS 样式
.resize-box {
  width: 100px;
  height: 100px;
  background-color: #007BFF;
  transition: transform 0.5s ease-in-out;
}

.resize-box:hover {
  transform: scale(1.2);
}

通过 transform 属性和过渡效果,我们创建了一个在鼠标悬停时会增大的动态效果,让元素在视觉上更加突出。

CSS过渡是编织网页动态美学的关键线索。通过精心设计的过渡效果,我们不仅能够增强用户的交互体验,还能给网站添加一层流畅而生动的视觉效果。记住,好的过渡应该像微风拂过湖面,轻柔而自然。掌握了这些技巧,就让我们的网站在用户的每一次操作中跳起优雅的舞蹈吧!

在这里插入图片描述


5.2 关键帧动画:编排你的网页芭蕾

在网页设计的舞台上,关键帧动画是那些能够让元素跳跃、旋转、闪烁甚至是变形的编排。通过定义动画的关键帧,我们可以精确控制动画从开始到结束的每一个步骤,创造出复杂而生动的视觉故事。

5.2.1 基础知识

  • 关键帧(Keyframes):使用 @keyframes 规则定义动画的序列,其中指定了动画开始和结束时的样式,以及中间的任何阶段。
  • 动画名称(Animation Name):在 @keyframes 规则中定义的动画名称,用于在元素上引用该动画。
  • 动画时长(Animation Duration):决定动画从开始到结束的时间长度。
  • 动画迭代(Animation Iteration):指定动画应该播放多少次,infinite 表示无限循环。
  • 动画方向(Animation Direction):控制动画播放的方向,如 normalreversealternate 等。
  • 动画延迟(Animation Delay):设置动画开始前的延迟时间。
  • 动画填充模式(Animation Fill Mode):决定动画在执行前后如何将样式应用于目标元素,例如 forwards 保留动画结束时的样式。

5.2.2 重点案例:呼吸效果的背景色变化

假设你想让一个元素的背景色呈现出呼吸般的渐变效果,模仿呼吸的节奏,让页面看起来更加生动。

  • CSS 样式
@keyframes breathe {
  0%, 100% { background-color: #88CCFF; }
  50% { background-color: #007BFF; }
}

.breathe-box {
  animation: breathe 5s ease-in-out infinite;
}

这个动画通过改变背景色在两种蓝色之间渐变,创造了一个平缓的呼吸效果。

5.2.3 拓展案例 1:滚动显示的文字

设计一个动画,让文字从左侧滚动进入,停留一会儿,然后继续滚动离开视口,类似于电影的开头字幕。

  • CSS 样式
@keyframes slideInAndOut {
  0% { transform: translateX(-100%); }
  10%, 90% { transform: translateX(0); }
  100% { transform: translateX(100%); }
}

.sliding-text {
  animation: slideInAndOut 10s ease-in-out infinite;
}

这个动画让文字像电影字幕一样滚动显示,增加了页面的动态效果和趣味性。

5.2.4 拓展案例 2:旋转进入的图标

假设你有一个社交媒体图标,希望它在页面加载时以旋转的方式出现,给用户一个有趣的视觉提示。

  • CSS 样式
@keyframes spinIn {
  from { transform: rotate(0deg) scale(0); }
  to { transform: rotate(360deg) scale(1); }
}

.social-icon {
  animation: spinIn 1s ease-out forwards;
}

通过这个动画,社交媒体图标在旋转的同时放大,从不可见到完全显示,创造了一个引人注目的入场效果。

关键帧动画提供了一种强大的方式来创造引人入胜的网页体验。它们让我们能够为网站的每一个元素编排独特的舞蹈,让整个页面充满活力和动感。通过细致地规划动画的每一步,我们不仅能够提升用户的参与度,还能以一种富有创造力的方式讲述我们的故事。所以,让我们拿起设计的画笔,为我们的网站编排一场精彩的芭蕾舞剧吧!

在这里插入图片描述


5.3 实用动画案例分析:优雅地迈出每一步

动画不仅仅是网页设计的点缀,它们是交流、引导和吸引用户注意力的强大工具。当用得恰到好处时,动画能够提升用户体验,使网站显得更加生动和互动。让我们通过一些实用的案例,探索如何在网页设计中优雅地应用动画。

5.3.1 基础知识

  • 性能考虑:优化动画性能以确保流畅的用户体验,避免使用过多复杂动画导致的卡顿。
  • 动画的目的:每个动画都应该有其存在的理由,无论是提升可用性、增强可访问性还是提供视觉反馈。
  • 适度原则:动画应该适度,过多或过于复杂的动画可能会分散用户的注意力,甚至导致不适。

5.3.2 重点案例:页面加载动画

假设你想要在网页加载时显示一个动画,以提升用户的等待体验,并平滑过渡到网页内容。

  • HTML 结构
<div class="loading-animation">加载中...</div>
  • CSS 样式
@keyframes fadeOut {
  to { opacity: 0; }
}

.loading-animation {
  animation: fadeOut 1s ease-out forwards;
  animation-delay: 2s; /* 假设加载需要一定时间 */
  opacity: 1;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  background: white;
  z-index: 1000;
}

这个案例展示了一个简单的页面加载动画,它在页面加载完成后渐渐淡出,为用户提供一个平滑的过渡效果。

5.3.3 拓展案例 1:滚动触发的动画

为了增加页面滚动的趣味性,可以为某些元素添加在滚动到视窗时才触发的动画。

  • CSS 样式
@keyframes slideUp {
  from { transform: translateY(20px); opacity: 0; }
  to { transform: translateY(0); opacity: 1; }
}

.scroll-animation {
  opacity: 0;
  animation: slideUp 0.5s ease-out forwards;
  animation-play-state: paused;
}

.scroll-animation.in-view {
  animation-play-state: running;
}
  • JavaScript
window.addEventListener('scroll', () => {
  document.querySelectorAll('.scroll-animation').forEach(el => {
    if (el.getBoundingClientRect().top < window.innerHeight) {
      el.classList.add('in-view');
    }
  });
});

这个案例结合了CSS动画和简单的JavaScript,为滚动到视窗内的元素添加动画,增加页面互动性。

5.3.4 拓展案例 2:数据仪表板的动态图表

在一个数据仪表板中,使用动画展示数据的变化可以帮助用户更好地理解数据。

  • HTML 结构
<div class="chart" style="--value:75;"></div>
  • CSS 样式
.chart {
  width: 100px;
  height: 100px;
  background: conic-gradient(#4caf50 var(--value), #ddd 0);
  border-radius: 50%;
  transition: background 1s ease-out;
}

通过改变CSS自定义属性 --value,可以在图表上创建动态变化的视觉效果,使数据展示更加直观和动态。

通过这些案例,我们看到了在网页设计中合理应用动画的重要性和价值。动画不仅能够提升用户体验,还能够在视觉上吸引用户,让信息传递更加有效。记住,优雅的动画应该是流畅和有目的的,像是网页的微妙舞步,引导用户体验每一刻的美好。继续探索和实验,让你的网站通过动画和过渡的魔法生动起来吧!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/382465.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

基于vue+node.js的校园跳蚤市场系统多商家

校园跳蚤市场系统可以在短时间内完成大量的数据处理、帮助用户快速的查找校园跳蚤市场相关信息&#xff0c;实现的效益更加直观。校园跳蚤市场系统中采用nodejs技术和mysql数据库。主要包括管理员、发布者和用户三大部分&#xff0c;主要功能是实现对个人中心、用户管理、发布者…

【MATLAB源码-第138期】基于matlab的D2D蜂窝通信仿真,对比启发式算法,最优化算法和随机算法的性能。

操作环境&#xff1a; MATLAB 2022a 1、算法描述 D2D蜂窝通信介绍 D2D蜂窝通信允许在同一蜂窝网络覆盖区域内的终端设备直接相互通信&#xff0c;而无需数据经过基站或网络核心部分转发。这种通信模式具有几个显著优点&#xff1a;首先&#xff0c;它可以显著降低通信延迟&…

大模型训练所需的硬件配置

1. 引入 训练一个大模型&#xff0c;到底需要投入多少块GPU&#xff0c;需要多少数据&#xff0c;训练多长时间能达到一个不错的效果&#xff1f; 本文引用靠谱的数据&#xff0c;来回答这些问题。 2. 全流程训练 大模型的训练&#xff0c;简单来说&#xff0c;分为Pretrain…

C#计算矩形面积:通过定义结构 vs 通过继承类

目录 一、涉及到的知识点 1、结构 2.结构和类的区别 3.继承 4.使用类继承提高程序的开发效率 二、实例&#xff1a;通过定义结构计算矩形面积 1.源码 2.生成效果 三、实例&#xff1a;通过继承类计算梯形面积 1.源码 2.生成效果 一、涉及到的知识点 1、结构 结构是…

git安装配置

1、下载安装 下载地址 2、配置git用户 git config --global user.name "yw" git config --global user.email "88888qq.com" 3、git init 初始化 4、生成ssh密钥 mkdir .ssh //创建文件夹cd .ssh //进入新建文件夹 ssh-keygen -t rsa // 输入密钥文…

推荐系统|召回05_矩阵补充、最近邻查找

文章目录 矩阵补充Matrix Completion模型结构模型训练模型存储 矩阵补充Matrix Completion 模型结构 通过用户ID和物品ID分别找到对应的向量&#xff0c;然后去做内积&#xff0c;内积的数值可以去衡量匹配的程度。 不共享参数的意思是指用户ID和物品ID使用不同的Embedding L…

LeetCode 144 二叉树的前序遍历

大家新年快乐&#xff0c;long年大吉 今天的题很简单&#xff0c;前序用栈就行。 电脑没拿&#xff0c;用我妈的pad艰难敲代码&#xff0c;敲字 知识点随便写点吧&#xff0c;这里基础点挺多&#xff0c;以后补充下 栈&#xff1a;先进后出&#xff0c;数据结构用stack&…

鸿蒙(HarmonyOS)项目方舟框架(ArkUI)之Blank组件

鸿蒙&#xff08;HarmonyOS&#xff09;项目方舟框架&#xff08;ArkUI&#xff09;之Blank组件 一、操作环境 操作系统: Windows 10 专业版、IDE:DevEco Studio 3.1、SDK:HarmonyOS 3.1 二、Blank组件 空白填充组件&#xff0c;在容器主轴方向上&#xff0c;空白填充组件具…

react中hook封装一个table组件 与 useColumns组件

目录 1&#xff1a;react中hook封装一个table组件依赖CommonTable / index.tsx使用组件效果 2&#xff1a;useColumns组件useColumns.tsx使用 1&#xff1a;react中hook封装一个table组件 依赖 cnpm i react-resizable --save cnpm i ahooks cnpm i --save-dev types/react-r…

前端JavaScript篇之对象创建的方式有哪些?

目录 对象创建的方式有哪些&#xff1f;1. 工厂模式&#xff1a;2. 构造函数模式&#xff1a;3. 原型模式&#xff1a;4. 混合模式&#xff1a;5. 动态原型模式&#xff1a;6. 寄生构造函数模式&#xff1a;7. 字面量方式&#xff1a; 对象创建的方式有哪些&#xff1f; JavaS…

elasticsearch增删改查

一、数据类型 1、字符串类型 &#xff08;1&#xff09;text &#xff08;2&#xff09;keyword 2、数值类型 &#xff08;1&#xff09;long、integer、short、byte、float、double 3、日期类型 &#xff08;1&#xff09;date 4、布尔类型 &#xff08;1&#xff0…

【Dubbo源码二:Dubbo服务导出】

入口 Dubbo服务导出的入口&#xff1a;服务导出是在DubboBootstrapApplicationListener在监听到ApplicationContextEvent的ContextRefreshedEvent事件后&#xff0c;会触发dubboBootstrap.start(), 在这个方法中最后会导出Dubbo服务 DubboBootstrapApplicationListener Dub…

指针的学习3

目录 字符指针变量 数组指针变量 二维数组传参的本质 函数指针变量 函数指针变量的创建 函数指针变量的使用 两段有趣的代码 typedef关键字 函数指针数组 转移表 回调函数&#xff1a; 字符指针变量 int main() {char arr[10] "abcdef";char* p1 arr;//…

机器学习2---逻辑回归(基础准备)

逻辑回归是基于线性回归是直线分的也可以做多分类 ## 数学基础 import numpy as np np.pi # 三角函数 np.sin() np.cos() np.tan() # 指数 y3**x # 对数 np.log10(10) np.log2(2) np.e np.log(np.e) #ln(e)# 对数运算 # log(AB) log(A) logB np.log(3*4)np.log(3)np.log(4) #…

vue electron 应用在windows系统上以管理员权限打开应用

打开package.json文件&#xff0c;在build下的win增加配置 "requestedExecutionLevel": "requireAdministrator",

前端JavaScript篇之对闭包的理解

目录 对闭包的理解用途循环中使用闭包解决 var 定义函数的问题 对闭包的理解 闭包是指一个函数能够访问并操作其词法作用域&#xff08;定义时所在的作用域&#xff09;之外的变量的能力。它可以通过在一个函数内部创建另一个函数来实现。内部函数可以访问外部函数的局部变量、…

6.0 Zookeeper session 基本原理详解教程

客户端与服务端之间的连接是基于 TCP 长连接&#xff0c;client 端连接 server 端默认的 2181 端口&#xff0c;也就 是 session 会话。 从第一次连接建立开始&#xff0c;客户端开始会话的生命周期&#xff0c;客户端向服务端的ping包请求&#xff0c;每个会话都可以设置一个…

HTML5+CSS3+移动web——HTML 基础

目录 一、标签语法 HTML的基本框架 1. 标题标签 2. 段落标签 3. 换行和水平线 4. 文本格式化标签 5. 图像标签 6. 路径 相对路径 绝对路径 7. 超链接标签 8. 音频 9. 视频 10. 注释 二、标签结构 一、标签语法 HTML 超文本标记语言——HyperText Markup Langua…

《动手学深度学习(PyTorch版)》笔记8.3

注&#xff1a;书中对代码的讲解并不详细&#xff0c;本文对很多细节做了详细注释。另外&#xff0c;书上的源代码是在Jupyter Notebook上运行的&#xff0c;较为分散&#xff0c;本文将代码集中起来&#xff0c;并加以完善&#xff0c;全部用vscode在python 3.9.18下测试通过&…

计算机网络——07协议层次及服务模型

协议层次及服务模型 协议层次 网络是一个复杂的系统 网络功能复杂&#xff1a;数字信号的物理信号承载、点到点、路由、rdt、进程区分、应用等现实来看&#xff0c;网络的许多构成元素和设备&#xff1a; 主机路由器各种媒体的链路应用协议硬件&#xff0c;软件 问题是&am…