《CSS 简易速速上手小册》第8章:CSS 性能优化和可访问性(2024 最新版)

news2024/10/6 5:26:41

在这里插入图片描述

文章目录

  • 8.1 CSS 文件的组织和管理
    • 8.1.1 基础知识
    • 8.1.2 重点案例:项目样式表结构
    • 8.1.3 拓展案例 1:使用BEM命名规范
    • 8.1.4 拓展案例 2:利用 Sass 混入创建响应式工具类
  • 8.2 提高网页加载速度的技巧
    • 8.2.1 基础知识
    • 8.2.2 重点案例:图片优化
    • 8.2.3 拓展案例 1:合并和压缩资源文件
    • 8.2.4 拓展案例 2:使用 CDN 和浏览器缓存
  • 8.3 设计可访问的 Web 界面
    • 8.3.1 基础知识讲解
    • 8.3.2 重点案例:构建可访问的表单
    • 8.3.3 拓展案例 1:使用合适的颜色对比度
    • 8.3.4 拓展案例 2:实现完全键盘可访问的导航

8.1 CSS 文件的组织和管理

良好的CSS文件组织和管理是维持大型项目可维护性的关键。随着项目规模的扩大,没有结构的CSS代码很容易变得难以管理和维护。通过采取一些策略和最佳实践,我们可以确保代码的可读性、可维护性和扩展性。

8.1.1 基础知识

  • 模块化:将CSS代码分割成多个模块或文件,每个模块负责一部分样式,例如布局、组件、工具类等。
  • 命名规范:采用一致的命名规范,如BEM(块、元素、修饰符),以确保类名的语义化和可读性。
  • 预处理器:使用Sass、Less等CSS预处理器,它们提供变量、混入、嵌套等功能,以支持更高级的CSS代码组织。
  • 注释:在CSS代码中添加注释,解释模块的用途、复杂的代码实现或特定的样式选择。

8.1.2 重点案例:项目样式表结构

假设你正在开发一个中到大型的Web应用,需要构建一个清晰、易于管理的CSS结构。

  • 样式目录结构
styles/
|
|-- base/
|   |-- _reset.scss       // 重置浏览器默认样式
|   |-- _typography.scss  // 设置基础字体样式
|
|-- components/
|   |-- _buttons.scss     // 按钮样式
|   |-- _cards.scss       // 卡片组件样式
|
|-- layouts/
|   |-- _header.scss      // 网站头部样式
|   |-- _footer.scss      // 网站底部样式
|
|-- utils/
|   |-- _variables.scss   // 存放所有Sass变量
|   |-- _mixins.scss      // 存放所有混入
|
|-- main.scss             // 主样式文件,@import所有其他文件

通过这种组织方式,我们可以将CSS代码分散到多个更小、更易于管理的文件中,而main.scss则用于汇总这些样式,便于编译。

8.1.3 拓展案例 1:使用BEM命名规范

为了避免样式冲突并提高CSS的可维护性,我们采用BEM命名规范来命名CSS类。

  • 示例代码
/* Block component */
.btn { ... }

/* Element that depends upon the block */ 
.btn__price { ... }

/* Modifier that changes the style of the block */
.btn--big { ... }

这种命名方法明确了CSS类的作用和关系,提高了代码的可读性和重用性。

8.1.4 拓展案例 2:利用 Sass 混入创建响应式工具类

使用Sass混入(Mixins)来创建一组响应式工具类,以快速应用媒体查询和响应式设计。

  • Sass Mixin 示例
@mixin respond-to($breakpoint) {
  @if $breakpoint == 'phone' {
    @media (max-width: 600px) { @content; }
  } @else if $breakpoint == 'tablet' {
    @media (max-width: 900px) { @content; }
  } @else if $breakpoint == 'desktop' {
    @media (min-width: 901px) { @content; }
  }
}

// 使用混入
@include respond-to('phone') {
  .example { font-size: 14px; }
}

通过使用Sass混入,我们可以以一种更干净、更可维护的方式实现响应式设计。

通过这些组织和管理CSS文件的策略,我们可以确保即使在最复杂的项目中,样式代码也能保持清晰和高效。随着技术的发展,始终保持代码的组织和结构,对于维护一个长期项目来说至关重要。

在这里插入图片描述


8.2 提高网页加载速度的技巧

在数字化时代,网页的加载速度不仅影响用户体验,也是搜索引擎排名的重要因素。快速加载的网页能够提升用户满意度,减少跳出率,并提高网站的整体表现。以下是一些提高网页加载速度的关键技巧和策略。

8.2.1 基础知识

  • 优化图片:图片通常是网页中体积最大的资源,通过压缩和格式选择,可以显著减少它们的大小。
  • 使用CDN(内容分发网络):CDN可以将内容缓存在全球多个位置,减少服务器响应时间。
  • 减少HTTP请求:通过合并文件、使用CSS精灵、内联小资源等方法减少页面的HTTP请求次数。
  • 异步加载资源:使用异步加载(如JavaScript的asyncdefer属性)可以防止阻塞渲染的脚本延迟页面的显示。
  • 利用浏览器缓存:通过设置合适的缓存策略,可以使回访用户更快地加载页面。

8.2.2 重点案例:图片优化

一个在线零售网站使用了大量的高分辨率产品图片,导致页面加载速度缓慢。

  • 优化步骤
    1. 压缩图片:使用工具如TinyPNG或ImageOptim压缩图片文件大小,而不损失可见的图片质量。
    2. 适当选择格式:对于图标和简单图形,使用SVG格式;对于照片,使用WebP或JPEG格式。
    3. 懒加载:实现图片的懒加载,使得页面初始化时只加载视口内的图片,其他图片在滚动到视口时才加载。

8.2.3 拓展案例 1:合并和压缩资源文件

一个博客网站有多个CSS和JavaScript文件,导致加载速度受影响。

  • 优化步骤
    1. 合并文件:将所有CSS文件合并为一个文件,所有JavaScript文件也合并为一个文件,减少HTTP请求的次数。
    2. 压缩文件:使用工具如UglifyJS和CSSNano等压缩资源文件,去除空格、注释,缩短变量名。

8.2.4 拓展案例 2:使用 CDN 和浏览器缓存

一个视频内容提供网站面临着全球用户的高延迟加载问题。

  • 优化步骤
    1. 部署CDN:选择一个性能良好的CDN服务提供商,将静态资源(如CSS、JavaScript和媒体文件)部署在CDN上,减少地理位置对加载速度的影响。
    2. 配置缓存策略:通过设置HTTP头Cache-ControlExpires,使浏览器缓存静态资源,减少回访用户的加载时间。

通过实施这些技巧,你可以显著提高网页的加载速度,从而改善用户体验和提升网站的SEO表现。记住,网页性能优化是一个持续的过程,定期评估和调整是必要的。使用工具如Google PageSpeed Insights和WebPageTest可以帮助你诊断性能问题并跟踪优化的效果。

在这里插入图片描述


8.3 设计可访问的 Web 界面

在构建网站时,确保每个人都能平等访问和使用你的网站是至关重要的。设计可访问的Web界面意味着要考虑到所有用户的需求,包括那些有视觉、听力、运动和认知障碍的人。通过遵循Web内容可访问性指南(WCAG),我们可以创建一个对所有人更加友好和包容的网络环境。

8.3.1 基础知识讲解

  • 语义化HTML:使用正确的HTML标签(如<header><nav><main><footer>)来提供清晰的文档结构,帮助屏幕阅读器正确解读页面内容。
  • 键盘导航:确保网站的所有功能都可以通过键盘访问,这对那些无法使用鼠标的用户尤其重要。
  • ARIA(Accessible Rich Internet Applications):当标准的HTML元素无法满足交互需求时,使用ARIA角色和属性增强元素的可访问性。
  • 颜色对比度:确保文本和其背景之间有足够的对比度,使得色盲用户和视力不佳的用户也能轻松阅读。
  • 替代文本:为所有非文本内容(如图片)提供替代文本,帮助视觉障碍用户理解内容。

8.3.2 重点案例:构建可访问的表单

表单是网站交互的重要组成部分,确保它们对所有用户都是可访问的至关重要。

  • HTML 结构
<form>
  <label for="name">姓名:</label>
  <input type="text" id="name" name="user_name">
  
  <label for="email">电子邮件:</label>
  <input type="email" id="email" name="user_email">
  
  <button type="submit">提交</button>
</form>
  • 关键实践
    • 使用<label>元素关联每个输入,提高表单的可访问性。
    • 为重要的表单控件提供明确的指示和错误提示。

8.3.3 拓展案例 1:使用合适的颜色对比度

为网站选择颜色时,确保文本内容与背景之间的对比度符合WCAG指南,至少达到AA级标准。

  • 实践技巧
    • 使用在线工具,如WebAIM的颜色对比度检查器,来验证你的颜色选择。
    • 在设计早期阶段就考虑对比度,确保设计的可访问性。

8.3.4 拓展案例 2:实现完全键盘可访问的导航

网站的导航菜单应该能够通过键盘完全访问,特别是对于那些无法使用鼠标的用户。

  • 实践技巧
    • 确保所有的交互元素(链接、按钮)都可以通过Tab键访问。
    • 使用focus样式提供视觉反馈,显示当前键盘焦点的位置。
    • 在JavaScript中处理keydown事件,以支持复杂的键盘交互。

通过实现这些可访问性最佳实践,我们不仅能够创建一个对所有用户都开放和友好的网站,还能提升我们的品牌形象和法律合规性。记住,设计可访问的Web界面是一个持续的过程,需要我们在设计和开发的每个阶段都保持关注和改进。让我们一起努力,为每个人打造更加开放、平等的数字世界。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

[NSSCTF]-Web:[SWPUCTF 2021 新生赛]easy_sql解析

查看网页 有提示&#xff0c;参数是wllm&#xff0c;并且要我们输入点东西 所以&#xff0c;我们尝试以get方式传入 有回显&#xff0c;但似乎没啥用 从上图看应该是字符型漏洞&#xff0c;单引号字符注入 先查看字段数 /?wllm2order by 3-- 没回显 报错了&#xff0c;说明…

算法学习——LeetCode力扣二叉树篇2

算法学习——LeetCode力扣二叉树篇2 107. 二叉树的层序遍历 II 107. 二叉树的层序遍历 II - 力扣&#xff08;LeetCode&#xff09; 描述 给你二叉树的根节点 root &#xff0c;返回其节点值 自底向上的层序遍历 。 &#xff08;即按从叶子节点所在层到根节点所在的层&#…

资产管理系统技术架构设计与实现

资产管理系统在现代金融领域扮演着至关重要的角色。它不仅帮助机构有效管理和优化资产配置&#xff0c;还提供了风险控制、绩效评估等功能。本文将探讨资产管理系统的技术架构设计与实现&#xff0c;以帮助读者深入了解该系统&#xff0c;并为其开发和部署提供参考。 1. 概述资…

Xray 工具笔记

Xray 官方文档 扫描单个url&#xff08;非爬虫&#xff09; 并输出文件&#xff08;不同文件类型&#xff09; .\xray.exe webscan --url 10.0.0.6:8080 --text-output result.txt --json-output result.json --html-output report.html默认启动所以内置插件 &#xff0c;指定…

AES加密中的CBC和ECB

目录 1.说明 2.ECB模式&#xff08;base64&#xff09; 3.CBC模式 1.说明 AES是常见的对称加密算法&#xff0c;加密和解密使用相同的密钥&#xff0c;流程如下&#xff1a; 主要概念如下&#xff1a; ①明文 ②密钥 用来加密明文的密码&#xff0c;在对称加密算法中&…

【网站项目】032汽车客运站管理系统

&#x1f64a;作者简介&#xff1a;拥有多年开发工作经验&#xff0c;分享技术代码帮助学生学习&#xff0c;独立完成自己的项目或者毕业设计。 代码可以私聊博主获取。&#x1f339;赠送计算机毕业设计600个选题excel文件&#xff0c;帮助大学选题。赠送开题报告模板&#xff…

ChatGLM3-6B的本地api调用

ChatGLM3-6B的本地api调用方式 1.运行openai_api_demo路径下的openai_api.py 启动后界面&#xff1a; 注意&#xff1a;本地api调到的前提是——本地部署了ChatGLM3-6B,本地部署的教程可参考&#xff1a; 20分钟部署ChatGLM3-6B 部署了若CUDA可用&#xff0c;默认会以CUDA方…

Kubernetes实战(二十六)-K8S 部署Dashboard UI

Kubernetes Dashboard是Kubernetes集群的通用、基于Web的UI。它允许用户管理集群中运行的应用程序并对其进行故障排除&#xff0c;以及管理集群本身。 访问到DashBoard有两种方式&#xff1a; 通过KubernetesAPI访问&#xff1a;Dashboard是Kubernetes的内置的UI插件&#xff…

第8章 智能租房——列表页

学习目标 掌握搜索房源列表页展示功能的逻辑&#xff0c;能够实现在列表中展示符合搜索条件的房源数据 掌握最新房源列表页展示功能的逻辑&#xff0c;能够运用分页插件以分页形式展示最新房源数据 掌握热点房源列表页展示功能的逻辑&#xff0c;能够运用分页插件以分页形式展…

《CSS 简易速速上手小册》第7章:CSS 预处理器与框架(2024 最新版)

文章目录 7.1 Sass&#xff1a;更高效的 CSS 编写7.1.1 基础知识7.1.2 重点案例&#xff1a;主题颜色和字体管理7.1.3 拓展案例 1&#xff1a;响应式辅助类7.1.4 拓展案例 2&#xff1a;深色模式支持 7.2 Bootstrap&#xff1a;快速原型设计和开发7.2.1 基础知识7.2.2 重点案例…

visual studio和cmake如何编译dlib库

官网 dlib C Library 对应的是最新版本&#xff0c;只能用到vs2015版本及以后 如果使用vs2013&#xff0c;所以需要下载vs2013可用的版本。 就是说dlib版本与vs版本有对应关系 所有版本 dlib C Library - Browse /dlib at SourceForge.net Releases davisking/dlib GitHu…

Trie 字典树的两种实现方式

Trie&#xff0c;又称字典树、单词查找树或键树&#xff0c;是一种树形结构&#xff0c;是一种哈希树的变种。典型应用是用于统计&#xff0c;排序和保存大量的字符串&#xff08;但不仅限于字符串&#xff09;&#xff0c;所以经常被搜索引擎系统用于文本词频统计。它的优点是…

Leetcode2560. 打家劫舍 IV

Every day a Leetcode 题目来源&#xff1a;2560. 打家劫舍 IV 解法1&#xff1a;二分答案 动态规划 给定数组 nums&#xff0c;从中选择一个长度至少为 k 的子序列 A&#xff0c;要求 A 中没有任何元素在 nums 中是相邻的。 最小化 max⁡(A)。 看到「最大化最小值」或者…

【Python 千题 —— 基础篇】查找年龄

Python 千题持续更新中 …… 脑图地址 👉:⭐https://twilight-fanyi.gitee.io/mind-map/Python千题.html⭐ 题目描述 题目描述 班级中有 Tom、Alan、Bob、Candy、Sandy 五个人,他们组成字典 {Tom: 23, Alan: 24, Bob: 21, Candy: 22, Sandy: 21},字典的键是姓名,字典的…

实现自定义标记

实现自定义标记 问题陈述 New Tech Book的高级管理层决定在其用JSP设计的应用程序的所有页面上显示版权信息。它们还要去如何向应用程序中添加JSP页面,可以重用显示版本信息的代码。公司的软件开发人员Jerry Smith决定用自定义标记来创建应用程序的这一部分。 解决方案 要解…

上位机图像处理和嵌入式模块部署(利用python开发软件)

【 声明&#xff1a;版权所有&#xff0c;欢迎转载&#xff0c;请勿用于商业用途。 联系信箱&#xff1a;feixiaoxing 163.com】 开发windows和linux软件的时候&#xff0c;大家一般都是习惯于用c/c语言进行开发&#xff0c;但是目前来说很多的开发板都是支持python语言开发的。…

Open CASCADE学习|扫掠

目录 1、BRepPrimAPI_MakePrism Draw Test Harness&#xff1a; C&#xff1a; 2、BRepPrimAPI_MakeRevol Draw Test Harness&#xff1a; C&#xff1a; 3、BRepOffsetAPI_MakePipeShell Draw Test Harness&#xff1a; C&#xff1a; Draw Test Harness&#xff1a;…

QXlsx Qt操作excel(2)

QXlsx 是一个用于处理Excel文件的开源C库。它允许你在你的C应用程序中读取和写入Microsoft Excel文件&#xff08;.xlsx格式&#xff09;。该库支持多种操作&#xff0c;包括创建新的工作簿、读取和写入单元格数据、格式化单元格、以及其他与Excel文件相关的功能。 关于QXlsx的…

Attention 和 Self-Attention 总结

一、Attention Attention 的核心逻辑是“从关注全部到关注重点”&#xff0c;将有限的注意力集中在重点信息上&#xff0c;从而节省资源&#xff0c;快速获得最有效的信息。 Attention 机制可以更加好的解决序列长距离依赖问题&#xff0c;并且具有并行计算能力。 Attention…

【计算几何】给定一组点的多边形面积

目录 一、说明二、有序顶点集三、无序顶点集3.1 凸多边形3.2 非凸多边形 四、结论 ​ 一、说明 计算多边形面积的方法有很多种。众所周知的多边形&#xff08;如三角形、矩形、正方形、梯形等&#xff09;的面积可以使用简单的数学公式计算。在这篇文章中&#xff0c;我将讨论…