HTML字符编码

了解什么是万维网?

万维网(world wide web)上的一个超媒体文档称之为一个页面外语:page)。

放置开始点的页面称为主页(外语:Homepage)或首页。

主页中通常包括有指向其他相关页面或其他节点的指针超级链接)。

超级链接,是一种统一资源定位器(Uniform Resource Locator,外语缩写URL)指针,通过激活(点击)它,可使浏览器方便地获取新的网页。

在逻辑上将视为一个整体的一系列页面的有机集合称为网站WebsiteSite)。

超级文本标记语言(英文缩写:HTML)是为“网页创建和其它可在网页浏览器中看到的信息”设计的一种标记语言。[2]

HTML的英文全称是 Hypertext Marked Language,即超文本标记语言

为了正确显示 HTML 页面,Web 浏览器必须知道要使用哪个字符集。

从 ASCII 到 UTF-8

ASCII 是第一个字符编码标准。ASCII 定义了 128 种可以在互联网上使用的字符:数字(0-9)、英文字母(A-Z)和一些特殊字符,比如:! $ + - ( ) @ < >。

ISO-8859-1 是 HTML 4 的默认字符集。此字符集支持 256 个不同的字符代码。HTML 4 同时支持 UTF-8。

ANSI(Windows-1252)是原始的 Windows 字符集。 ANSI 与 ISO-8859-1 相同,不同之处在于 ANSI 具有 32 个额外的字符。

HTML5 规范鼓励 Web 开发人员使用 UTF-8 字符集,该字符集涵盖了世界上几乎所有的字符和符号!

( UTF-8(8-bit Unicode Transformation Format)是一种针对Unicode的可变长度字符编码,又称万国码。由Ken Thompson于1992年创建。现在已经标准化为RFC 3629。UTF-8用1到6个字节编码UNICODE字符。用在网页上可以同一页面显示中文简体繁体及其它语言(如英文,日文,韩文)。)

服务器向浏览器发送 HTML 网页文件时,会通过 HTTP 头信息,声明网页的编码方式。

Content-Type: text/html; charset=UTF-8

上面代码中,HTTP 头信息的`Content-Type`字段先声明,服务器发送的数据类型是`text/html`(即 HTML 网页),然后声明网页的文字编码是`UTF-8`。

网页内部也会再用`<meta>`标签,再次声明网页的编码。

<meta charset="UTF-8">

UTF-8

每个字符有一个 Unicode 号码,称为码点(code point)。如果知道码点,就能查到这是什么字符。举例来说,英文字母`a`的码点是十进制的`97`(十六进制的`61`),汉字“中”的码点是十进制的`20013`(十六进制的`4e2d`)。

由于下面的原因,不是每一个 Unicode 字符都能直接在 HTML 语言里面显示。

(1)不是每个 Unicode 字符都可以打印出来,有些没有可打印形式,比如换行符的码点是十进制的`10`(十六进制的`A`),就没有对应的字面形式。

(2)小于号(`<`)和大于号(`>`)用来定义 HTML 标签,其他需要用到这两个符号的场合,必须防止它们被解释成标签。

(3)由于 Unicode 字符太多,无法找到一种输入法,可以直接输入所有这些字符。换言之,没有一种键盘,有办法输入所有符号。

(4)网页不允许混合使用多种编码,如果使用 UTF-8 编码的同时,又想插入其他编码的字符,就会很困难。

HTML 为了解决上面这些问题,允许使用 Unicode 码点表示字符,浏览器会自动将码点转成对应的字符。

字符的码点表示法是`&#N;`(十进制,`N`代表码点)或者`&#xN;`(十六进制,`N`代表码点),比如,字符`a`可以写成`&#97;`(十进制)或者`&#x61;`(十六进制),字符`中`可以写成`&#20013;`(十进制)或者`&#x4e2d;`(十六进制),浏览器会自动转换它们。

```html

<p>hello</p>

<!-- 等同于 -->

<p>&#104;&#101;&#108;&#108;&#111;</p>

<!-- 等同于 -->

<p>&#x68;&#x65;&#x6c;&#x6c;&#x6f;</p>

```

上面代码中,字符可以直接表示,也可以使用十进制码点或十六进制码点表示。

注意,HTML 标签本身不能使用码点表示,否则浏览器会认为这是所要显示的文本内容,而不是标签。比如,`<p>`一旦写成`<&#112;>`或者`&#60;&#112;&#62;`,浏览器就不再认为这是标签了,而会当作文本内容将其显示为`<p>`。

## 字符的实体表示法

数字表示法的不方便之处,在于必须知道每个字符的码点,很难记忆。为了能够快速输入,HTML 为一些特殊字符,规定了容易记忆的名字,允许通过名字来表示它们,这称为实体表示法(entity)。

实体的写法是`&name;`,其中的`name`是字符的名字。下面是其中一些特殊字符,及其对应的实体。

- `<`:`&lt;`

- `>`:`&gt;`

- `"`:`&quot;`

- `'`:`&apos;`

- `&`:`&amp;`

- `©`:`&copy;`

- `#`:`&num;`

- `§`:`&sect;`

- `¥`:`&yen;`

- `$`:`&dollar;`

- `£`:`&pound;`

- `¢`:`&cent;`

- `%`:`&percnt;`

- `*`:`$ast;`

- `@`:`&commat;`

- `^`:`&Hat;`

- `±`:`&plusmn;`

- 空格:`&nbsp;`

注意,上面最后一个特殊字符是空格,它也有对应的实体表示法。

字符的数字表示法和实体表示法,都可以表示正常情况无法输入的字符,逃脱了浏览器的限制,所以英语里面称为“escape”,中文翻译为“字符的转义”。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值