当前位置: 首页 > news >正文

HTML 理论系统笔记2

语义化 HTML 学习笔记

​ 语义化是一个自然的趋势,这是为了将真正的优化交给专门的层次做,人来更好的可读和维护我们的代码,在现代 Web 开发中,HTML 不仅仅是为了显示内容,更是传递结构与语义的语言。理解语义化 HTML,可以让我们的网页在可访问性、SEO、可维护性等方面都更出色。


所以什么是语义化(Semantic)HTML?

语义化 HTML 指的是使用能够表达内容意义的标签来构建网页,而不是单纯用 <div><span> 包裹所有内容。举个例子,下面就是一个现代的HTML网页描述

<header><h1>My Blog</h1><nav><ul><li><a href="/">Home</a></li><li><a href="/about">About</a></li></ul></nav>
</header>
<main><article><h2>Understanding CSS</h2><p>CSS is a stylesheet language used to describe the presentation of a document written in HTML.</p></article><aside><h3>Related Articles</h3><ul><li><a href="#">HTML Basics</a></li><li><a href="#">JavaScript Tips</a></li></ul></aside>
</main>
<footer><p>&copy; 2025 My Blog</p>
</footer>

在上面的代码中,每个标签都有明确的意义:

  • <header> 表示页眉;
  • <nav> 表示导航菜单;
  • <main> 是主体内容;
  • <article> 表示独立的文章块;
  • <aside> 是侧边栏或补充内容;
  • <footer> 是页脚。

这样的结构不仅让开发者一眼就能看懂,也让屏幕阅读器和搜索引擎轻松理解页面结构。


为什么要关心语义化 HTML?

当然,不光是可维护性,咱们还有很多其他实实在在的好处可以考虑。比如说

可访问性提升

屏幕阅读器和其他辅助技术依赖 HTML 的语义来理解页面。例如:

<h2>最新文章</h2>
<ul><li><a href="#">CSS 入门指南</a></li><li><a href="#">JavaScript 异步学习</a></li>
</ul>

这里 <h2> 明确标记了“最新文章”的标题,辅助设备可以快速跳转和朗读,让视觉受限用户也能高效浏览内容。

SEO 更友好

搜索引擎通过语义标签理解页面内容:

  • <article> 表示独立条目;
  • <header><footer> 帮助区分页面结构;
  • <nav> 告诉搜索引擎哪些是导航链接。
可维护性与可读性

当团队协作时,语义化的 HTML 让同事更容易理解页面结构,减少注释依赖,也方便后期样式或功能扩展。

样式与结构分离

语义化 HTML 鼓励把内容结构和样式分开,通过 CSS 控制外观,而不是靠 <div> + 类名堆积样式。


良好的结构层次(Hierarchy)为何重要?

不要用 CSS 的 font-size 去模拟标题层级,语义性优先。

HTML 的标题标签 <h1><h6> 定义了文档的大纲(document outline):

<h1>网页设计入门</h1>
<h2>HTML 基础</h2>
<h3>标签与属性</h3>
<h2>CSS 基础</h2>
<h3>选择器与优先级</h3>

一个良好的正确的层次可以提升可读性,用户可快速扫描信息,帮助屏幕阅读器理解内容层级。避免搜索引擎抓取混乱。


呈现型 HTML vs 语义化 HTML

表现型 HTML:关注外观或布局,过度使用 <b>, <i><div>/<span>

<div class="header"><div class="logo">My Site</div><div class="menu">...</div>
</div>

语义化 HTML:标记表达内容意义,结构清晰:

<header><div class="logo">My Site</div><nav>...</nav>
</header>

更多语义对比示例

<!-- 不推荐 -->
<b>重要提示</b>
<i>强调内容</i><!-- 推荐 -->
<strong>重要提示</strong>
<em>强调内容</em>
  • <strong><em> 表示语义上重要或强调;
  • <b><i> 仅视觉效果,无语义意义。

常用语义元素与用途

类型常用标签用途
文档结构<header>, <nav>, <main>, <aside>, <section>, <article>, <footer>页面或区块结构
文本语义<p>, <h1><h6>, <blockquote>, <cite>, <q>, <address>段落、标题、引用、联系信息
强调<strong>, <em>, <mark>重要或强调内容
列表<ul>, <ol>, <li>, <dl>, <dt>, <dd>有序/无序列表或定义列表
媒体<figure>, <figcaption>, <picture>, <img alt="">, <audio>, <video>图片、音频、视频及说明
表单<form>, <label>, <fieldset>, <legend>, <input>, <button>, <select>用户输入交互
表格<table>, <thead>, <tbody>, <tfoot>, <tr>, <th>, <td>数据表格
http://www.dtcms.com/a/536182.html

相关文章:

  • 微软Copilot被用于窃取OAuth令牌,AI Agent成为攻击者帮凶
  • 免费网站建站w海口企业自助建站
  • 全球 PyTorch 大会与 Triton 大会释放强信号:算子语言繁荣和分化背后,编译器核心地位日益凸显
  • PyCharm 快速运行 django project
  • 自己动手制作网站外呼电销系统
  • 网站建设出错1004有专门下载地图做方案的网站吗
  • OpenCV C++ 中,访问图像像素三种常用方法
  • MATLAB基于小波云模型时间序列预测,以年径流预测为例
  • 项目名称:烟酒进销存管理系统
  • web开发,在线%蛋糕销售%管理系统,基于asp.net,webform,c#,sql server
  • UE5 蓝图-25:主 mainUI界面蓝图,右侧的颜色按钮的实现,换色逻辑与材质参数集,
  • 腾讯优图开源Youtu-Embedding通用文本表示模型,用处在哪?
  • parser_error UnicodeDecodeError: ‘utf-8‘ codec can‘t decode bytes
  • 慕课网站开发wordpress 当前页面登录密码
  • 从零学习 Agentic RL(四)—— 超越 ReAct 的线性束缚:深入解析 Tree-of-Thoughts (ToT)
  • 宁德城乡建设网站首页无法删除wordpress
  • Spring Boot3零基础教程,天气 API 测试,笔记73
  • 基于 STM32 的智能语音唤醒与关键词识别系统设计 —— 从硬件集成到算法实现
  • Redis数据库基础命令
  • 1.3 StorageTransient的gas计算
  • 物联网技术与基础第六节上课笔记
  • SAP SD系统开票查询报表分享
  • it网站设计培训制作网站的工具
  • 南京网站建设工作室电商卖什么产品有前景
  • iOS 开发推送功能全流程详解 从 APNs 配置到上架发布的完整实践(含跨平台上传方案)
  • 李宏毅机器学习笔记33
  • 深入理解Bitbucket Pipelines:强大的CICD开源解决方案
  • Android 14 系统启动流程深度解析:rc文件的语法、解析及常见语法详解
  • 商城网站的seo优化改怎么做软件公司 网站建设费分录
  • 免费做淘宝客网站有哪些石家庄网站优化推广