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

【HTML-5】HTML 实体:完整指南与最佳实践

1. 什么是 HTML 实体?

HTML 实体是一种在 HTML 文档中表示特殊字符的方法,这些字符如果直接使用可能会与 HTML 标记混淆,或者无法通过键盘直接输入。实体由 & 符号开始,以 ; 分号结束。

<p>这是一个小于符号的实体:&lt;</p>

2. 为什么需要使用 HTML 实体?

  1. 避免与 HTML 标签冲突:某些字符如 <> 是 HTML 标签的一部分,直接使用可能导致解析错误。

  2. 显示键盘上没有的字符:如版权符号 (©)、商标符号 (™) 等。

  3. 确保字符在不同编码下正确显示:特别是当文档编码与服务器设置不一致时。

3. HTML 实体的三种表示方式

3.1 命名实体

最易读的形式,使用容易记忆的名称:

&实体名称;

常见命名实体:

  • &lt; - 小于号 (<)
  • &gt; - 大于号 (>)
  • &amp; - 和号 (&)
  • &quot; - 双引号 (")
  • &apos; - 单引号 (')
  • &nbsp; - 不换行空格
  • &copy; - 版权符号 (©)
  • &reg; - 注册商标符号 (®)

3.2 数字实体(十进制)

使用字符的十进制 Unicode 码点:

&#数字;

示例:

  • &#60; - <
  • &#169; - ©

3.3 数字实体(十六进制)

使用字符的十六进制 Unicode 码点:

&#x十六进制数字;

示例:

  • &#x3C; - <
  • &#xA9; - ©

4. 常用的 HTML 实体分类

4.1 保留字符(必须转义)

字符实体名称实体编号
<&lt;&#60;
>&gt;&#62;
&&amp;&#38;
"&quot;&#34;
&apos;&#39;

4.2 常用符号

符号实体名称实体编号
©&copy;&#169;
®&reg;&#174;
&trade;&#8482;
&euro;&#8364;
£&pound;&#163;
¥&yen;&#165;
§&sect;&#167;
&para;&#182;

4.3 空格相关

描述实体名称实体编号
不换行空格&nbsp;&#160;
半角空格&ensp;&#8194;
全角空格&emsp;&#8195;
窄空格&thinsp;&#8201;

4.4 数学符号

符号实体名称实体编号
×&times;&#215;
÷&divide;&#247;
±&plusmn;&#177;
&infin;&#8734;
&sum;&#8721;
&radic;&#8730;
&ne;&#8800;

4.5 箭头

符号实体名称实体编号
&larr;&#8592;
&rarr;&#8594;
&uarr;&#8593;
&darr;&#8595;
&harr;&#8596;

5. 实际应用示例

5.1 在 HTML 中显示代码

<pre>
&lt;div class="container"&gt;&lt;p&gt;这是一个段落&lt;/p&gt;
&lt;/div&gt;
</pre>

5.2 特殊符号的使用

<p>版权所有 &copy; 2023 我的公司&trade;。价格:&euro;99.99</p>

5.3 数学表达式

<p>勾股定理:a&sup2; + b&sup2; = c&sup2;</p>
<p>积分符号:&int; f(x)dx</p>

6. HTML5 中的变化

HTML5 引入了许多新的实体,特别是数学符号和图形符号。同时,HTML5 对实体解析更加宽松:

  1. 某些情况下可以省略分号(但不推荐)
  2. 支持更多的数学和符号实体
  3. 对未知实体更宽容(会作为文本显示)

7. 最佳实践

  1. 始终使用命名实体(当可用时),因为它们更易读和维护
  2. 不要过度使用 &nbsp; 进行布局控制 - 应该使用 CSS
  3. 对于常用符号,考虑直接使用 Unicode 字符(如果编码支持)
  4. 在属性值中,必须对引号进行转义
  5. 在 JavaScript 中生成 HTML 时,确保正确转义

8. 常见问题解答

Q: 什么时候必须使用 HTML 实体?
A: 必须使用实体的情况包括:

  • 当字符是 HTML 语法的一部分(如 <, >, &
  • 当字符在属性值中且与属性引号冲突时
  • 当字符可能因编码问题无法正确显示时

Q: 如何输入 Emoji?需要使用实体吗?
A: 现代浏览器通常支持直接输入 Emoji(如 😊),但也可以使用数字实体(如 &#128522; 表示 😊)。

Q: &nbsp; 和普通空格有什么区别?
A: &nbsp; 是"不换行空格",浏览器不会在此处换行,而普通空格在换行时会被当作空格处理。

9. 工具与资源

  1. W3C 官方实体列表
  2. 实体转换工具
  3. Unicode 字符查找

10. 总结

HTML 实体是网页开发中不可或缺的一部分,正确处理特殊字符可以避免许多显示问题和语法错误。掌握常用的 HTML 实体不仅能提高代码质量,还能让你的网页内容更加丰富和专业。随着 HTML5 的发展,实体支持越来越完善,开发者可以更自由地表达各种符号和特殊字符。

记住关键原则:当字符可能引起歧义或无法保证正确显示时,使用实体是最安全的选择。

相关文章:

【HTML-5】HTML 实体:完整指南与最佳实践

1. 什么是 HTML 实体&#xff1f; HTML 实体是一种在 HTML 文档中表示特殊字符的方法&#xff0c;这些字符如果直接使用可能会与 HTML 标记混淆&#xff0c;或者无法通过键盘直接输入。实体由 & 符号开始&#xff0c;以 ; 分号结束。 <p>这是一个小于符号的实体&am…...

SpringBoot 项目实现操作日志的记录(使用 AOP 注解模式)

本文是博主在做关于如何记录用户操作日志时做的记录&#xff0c;常见的项目中难免存在一些需要记录重要日志的部分&#xff0c;例如权限和角色设定&#xff0c;重要数据的操作等部分。 博主使用 Spring 中的 AOP 功能&#xff0c;结合注解的方式&#xff0c;对用户操作过的一些…...

AI|Java开发 IntelliJ IDEA中接入本地部署的deepseek方法

目录 连接本地部署的deepseek&#xff1a; IntelliJ IDEA中使用deepseek等AI&#xff1a; 用法一&#xff1a;让AI写代码 用法二&#xff1a;选中这段代码&#xff0c;右键&#xff0c;可以让其解释这段代码的含义。这时显示的解释是英文的。 连接本地部署的deepseek&#…...

【疑难杂症】Vue前端下载文件无法打开 已解决

由于刚学了VUE不久&#xff0c;不清楚底层逻辑。我遇到从后台下载文件无法打开的问题。 测试下来是&#xff0c;请求时未设置 responseType: blob。 axios 默认的 responseType 是 json &#xff0c;会尝试将响应体解析为JSON。但文件下载场景需要后端返回二进制流&#xff0…...

【1——Android端添加隐私协议(unity)1/3】

前言&#xff1a;这篇仅对于unity 发布Android端上架国内应用商店添加隐私协议&#xff0c;隐私协议是很重要的东西&#xff0c;没有这个东西&#xff0c;是不上了应用商店的。 对于仅仅添加隐私协议&#xff0c;我知道有三种方式,第一种和第二种基本一样 1.直接在unity里面新…...

Linux之概述和安装vm虚拟机

文章目录 操作系统概述硬件和软件操作系统常见操作系统 初识LinuxLinux的诞生Linux内核Linux发行版 虚拟机介绍虚拟机 VMware WorkStation安装虚拟化软件VMware WorkStation 安装查看VM网络连接设置VM存储位置 在VMware上安装Linux(发行版CentOS7)安装包获取CentOS7 安装 Mac系…...

深入理解 Linux 的 set、env 和 printenv 命令

在 Linux 和类 Unix 系统中&#xff0c;环境变量是配置和管理 Shell 及进程行为的核心机制。set、env 和 printenv 是与环境变量交互的三个重要命令&#xff0c;每个命令都有其独特的功能和用途。本文将详细探讨这三个命令的区别&#xff0c;帮助大家更好地理解和使用这些命令。…...

LeetCode热题100--19.删除链表的倒数第N个结点--中等

1. 题目 给你一个链表&#xff0c;删除链表的倒数第 n 个结点&#xff0c;并且返回链表的头结点。 示例 1&#xff1a; 输入&#xff1a;head [1,2,3,4,5], n 2 输出&#xff1a;[1,2,3,5] 示例 2&#xff1a; 输入&#xff1a;head [1], n 1 输出&#xff1a;[] 示例…...

开发AR导航助手:ARKit+Unity+Mapbox全流程实战教程

引言 在增强现实技术飞速发展的今天&#xff0c;AR导航应用正逐步改变人们的出行方式。本文将手把手教你使用UnityARKitMapbox开发跨平台AR导航助手&#xff0c;实现从虚拟路径叠加到空间感知的完整技术闭环。通过本教程&#xff0c;你将掌握&#xff1a; AR空间映射与场景理…...

git学习与使用(远程仓库、分支、工作流)

文章目录 前言简介git的工作流程git的安装配置git环境&#xff1a;git config --globalgit的基本使用新建目录初始化仓库&#xff08;repository&#xff09;添加到暂存区新增/修改/删除 文件状态会改变 提交到仓库查看提交&#xff08;commit&#xff09;的历史记录git其他命令…...

嵌入式预处理链接脚本lds和map文件

在嵌入式开发中&#xff0c;.lds.S 文件是一个 预处理后的链接脚本&#xff08;Linker Script&#xff09;&#xff0c;它结合了 C 预处理器&#xff08;Preprocessor&#xff09; 的功能和链接脚本的语法。它的核心作用仍然是 定义内存布局和链接规则&#xff0c;但通过预处理…...

9. Spring AI 各版本的详细功能与发布时间整理

目录 一、旧版本(Legacy) 0.8.1(2024年3月) 二、里程碑版本(Milestone) 1.0.0-M1(2024年5月30日) 1.0.0-M2(2024年7月) 1.0.0-M3(2024年10月8日) 1.0.0-M4(2024年12月) 1.0.0-M5(2025年1月9日) 1.0.0-M6(2025年3月) 1.0.0-M7(2025年4月14日) 1.…...

《Android 应用开发基础教程》——第十四章:Android 多线程编程与异步任务机制(Handler、AsyncTask、线程池等)

目录 第十四章&#xff1a;Android 多线程编程与异步任务机制&#xff08;Handler、AsyncTask、线程池等&#xff09; &#x1f538; 14.1 为什么需要多线程&#xff1f; &#x1f538; 14.2 Handler Thread 模型 ✦ 使用 Handler 与 Thread 进行线程通信 ✦ 简要说明&am…...

Apache 高级配置实战:从连接保持到日志分析的完整指南

Apache 高级配置实战&#xff1a;从连接保持到日志分析的完整指南 前言 最近在深入学习 Apache 服务器配置时&#xff0c;发现很多朋友对 Apache 的高级功能还不够了解。作为一个在运维路上摸爬滚打的技术人&#xff0c;我想把这些实用的配置技巧分享给大家。今天这篇文章会带…...

开源 OIDC(OpenID Connect)身份提供方(IdP)、iam选型

文章目录 开源 OIDC(OpenID Connect)身份提供方(IdP)、iam选型主流开源 OIDC(OpenID Connect)身份提供方(IdP)zitadeldexory开源 OIDC(OpenID Connect)身份提供方(IdP)、iam选型 主流开源 OIDC(OpenID Connect)身份提供方(IdP) 当前主流的**开源 OIDC(OpenI…...

Android OkHttp控制链:深入理解网络请求的流程管理

OkHttp作为Android和Java平台上广泛使用的HTTP客户端&#xff0c;其核心设计之一就是"控制链"(Chain)机制。本文将深入探讨OkHttp控制链的工作原理、实现细节以及如何利用这一机制进行高级定制。 一、什么是OkHttp控制链 OkHttp控制链是一种责任链模式的实现&#…...

【JVM 01-引言入门篇】

JVM 引言篇01 笔记记录 1. 什么是JVM&#xff1f;2. 学习JVM有什么用&#xff1f;3. 常见的JVM4. 学习路线 学习资料来源-b站黑马 1. 什么是JVM&#xff1f; 定义&#xff1a;Java虚拟机&#xff08;Java Virtual Machine 简称JVM&#xff09;是运行所有Java程序的抽象计算机&a…...

Pandas数据规整

&#xff08;1&#xff09;层次化索引 1.创建带层次化索引的df 第一种&#xff0c;直接创建 import pandas as pd import numpy as npdata pd.Series(np.random.randn(9),index [[a, a, a, b, b, c, c, d, d],[1, 2, 3, 1, 3, 1, 2, 2, 3]]) print(data) # a 1 -0.6416…...

ThreadLocal线程本地变量在dubbo服务使用时候遇到的一个坑

我昨天遇到一个问题&#xff0c;就是我springboot项目里面有一个提供代办服务审核的dubbo接口&#xff0c;这个接口给房源项目调用&#xff0c;但是碰到一个问题就是&#xff0c;房源项目每天凌晨5点会查询满足条件过期的数据&#xff0c;然后调用我这边的代办审核dubbo接口&am…...

pga 作用

Oracle pga的作用 PGA 内存结构与功能解释&#xff1a; PGA ├── 1. Private SQL Area ├── 2. Session Memory ├── 3. SQL Work Areas │ ├── Sort Area │ ├── Hash Area │ ├── Bitmap Merge Area │ └── Bitmap Create Area └── 4. Stack S…...

setup.py Pip wheel

. ├── my_package │ ├── __init__.py │ └── my_file.py └── setup.pymy_file.py def my_func():print("Hello World")setup.py from setuptools import setup, find_packages import datetimesetup(namemy_package, # 记得改version0.1.1,packag…...

GO 语言进阶之 时间处理和Json 处理

更多个人笔记见&#xff1a; github个人笔记仓库 gitee 个人笔记仓库 个人学习&#xff0c;学习过程中还会不断补充&#xff5e; &#xff08;后续会更新在github上&#xff09; 文章目录 时间处理基本例子 Json处理基础案例 时间处理 时间格式化必须使用&#xff1a;2006-01-…...

对WireShark 中的UDP抓包数据进行解析

对WireShark 中的UDP抓包数据进行解析 本文尝试对 WireShark 中抓包的 UDP 数据进行解析。 但是在尝试对 TCP 中的 FTP 数据进行解析的时候&#xff0c;发现除了从端口号进行区分之外&#xff0c; 没有什么好的方式来进行处理。 import numpy as np import matplotlib.pyplot …...

Flannel后端为UDP模式下,分析数据包的发送方式(二)

发往 10.244.2.5 的数据包最终会经过物理网卡 enp0s3&#xff0c;尽管路由表直接指定通过 flannel.1 发出。以下以 Markdown 格式详细解释为什么会经过 enp0s3&#xff0c;结合 Kubernetes 和 Flannel UDP 模式的背景。 问题分析 在 Kubernetes 环境中&#xff0c;使用 Flanne…...

从 0 到 1:Spring Boot 与 Spring AI 深度实战(基于深度求索 DeepSeek)

在人工智能技术与企业级开发深度融合的今天&#xff0c;传统软件开发模式与 AI 工程化开发的差异日益显著。作为 Spring 生态体系中专注于 AI 工程化的核心框架&#xff0c;Spring AI通过标准化集成方案大幅降低 AI 应用开发门槛。本文将以国产大模型代表 ** 深度求索&#xff…...

upload-labs通关笔记-第20关 文件上传之杠点绕过

系列目录 upload-labs通关笔记-第1关 文件上传之前端绕过&#xff08;3种渗透方法&#xff09; upload-labs通关笔记-第2关 文件上传之MIME绕过-CSDN博客 upload-labs通关笔记-第3关 文件上传之黑名单绕过-CSDN博客 upload-labs通关笔记-第4关 文件上传之.htacess绕过-CSDN…...

Vscode +Keil Assistant编译报错处理

Vscode Keil Assistant编译报错处理 1.报错图片内容 所在位置 行:1 字符: 25 chcp.com 65001 -Command & c:\Users\92170.vscode\extensions\cl.keil-a … ~ 不允许使用与号(&)。& 运算符是为将来使用而保留的&#xff1b;请用双引号将与号引起来(“&”)&…...

记录python在excel中添加一列新的列

思路是&#xff0c;先将需要添加为新的列存储到一个暂时的列表中&#xff0c;然后用到以下函数来存储 data_.loc[:, "新列的名字"] save_list_ 上面的save_list_就是暂时存储了信息的列表了。 以下是我的代码&#xff0c;供以后快速回忆。 schools_data {"98…...

WebRTC:实时通信的未来之路

WebRTC&#xff1a;实时通信的未来之路 目录 WebRTC&#xff1a;实时通信的未来之路一、背景介绍二、使用方式三、前途展望 一、背景介绍 随着互联网的飞速发展&#xff0c;实时音视频通信需求日益增长。传统的音视频通信多依赖于专有协议和插件&#xff08;如Flash、ActiveX等…...

探索产品经理的MVP:从概念到实践

在产品开发的世界里&#xff0c;MVP&#xff08;Minimum Viable Product&#xff0c;最小可行产品&#xff09;是一个至关重要的概念。它不仅帮助团队快速验证假设&#xff0c;还能降低失败风险&#xff0c;为后续的产品迭代奠定坚实的基础。本文将深入探讨MVP的概念、重要性及…...