1 HTML字符实体(Character Entities),转义字符串(Escape Sequence)为什么要用转义字符串?
  2 HTML中<,>,&等有特殊含义(<,>,用于链接签,&用于转义),不能直接使用。这些符号是不显示在我们最终看到的网页里的,那如果我们希望在网页中显示这些符号,该怎么办呢? 
  3 
  4 这就要说到HTML转义字符串(Escape Sequence)了。 
  5 
  6 转义字符串(Escape Sequence)也称字符实体(Character Entity)。在HTML中,定义转义字符串的原因有两个:第一个原因是像“<”和“>”这类符号已经用来表示HTML标签,因此就不能直接当作文本中的符号来使用。为了在HTML文档中使用这些符号,就需要定义它的转义字符串。当解释程序遇到这类字符串时就把它解释为真实的字符。在输入转义字符串时,要严格遵守字母大小写的规则。第二个原因是,有些字符在ASCII字符集中没有定义,因此需要使用转义字符串来表示。
  7 
  8 转义字符串的组成
  9 转义字符串(Escape Sequence),即字符实体(Character Entity)分成三部分:第一部分是一个&符号,英文叫ampersand;第二部分是实体(Entity)名字或者是#加上实体(Entity)编号;第三部分是一个分号。 
 10 
 11 比如,要显示小于号(<),就可以写 < 或者 < 。 
 12 
 13 用实体(Entity)名字的好处是比较好理解,一看lt,大概就猜出是less than的意思,但是其劣势在于并不是所有的浏览器都支持最新的Entity名字。而实体(Entity)编号,各种浏览器都能处理。 
 14 
 15 提示:实体名称(Entity)是区分大小写的。 
 16 
 17 备注:同一个符号,可以用“实体名称”和“实体编号”两种方式引用,“实体名称”的优势在于便于记忆,但不能保证所有的浏览器都能顺利识别它,而“实体编号”则没有这种担忧,但它实在不方便记忆。 
 18 
 19 如何显示空格?
 20 通常情况下,HTML会自动截去多余的空格。不管你加多少空格,都被看做一个空格。比如你在两个字之间加了10个空格,HTML会截去9个空格,只保留一个。为了在网页中增加空格,你可以使用 表示空格。 
 21 
 22 --------------------------------------------------------------------------------
 23 
 24 HTML特殊转义字符列表
 25 最常用的字符实体
 26 Character Entities
 27 显示 说明 实体名称 实体编号 
 28  半方大的空白     
 29 
 30  全方大的空白     
 31 
 32  不断行的空白格     
 33 < 小于 < < 
 34 > 大于 > > 
 35 & &符号 & & 
 36 " 双引号 " " 
 37 © 版权 © © 
 38 ® 已注册商标 ® ® 
 39 ™ 商标(美国) ™ ™ 
 40 
 41 × 乘号 × × 
 42 ÷ 除号 ÷ ÷ 
 43 ISO 8859-1 (Latin-1)字符集
 44 HTML 4.01 支持 ISO 8859-1 (Latin-1) 字符集。 
 45 
 46 备注:为了方便起见,以下表格中,“实体名称”简称为“名称”,“实体编号”简称为“编号” 
 47 
 48 显示 名称 编号 显示 名称 编号 显示 名称 编号 显示 名称 编号 显示 名称 编号 
 49       ¡ ¡ ¡ ¢ ¢ ¢ £ £ £ ¤ ¤ ¤ 
 50 ¥ ¥ ¥ ¦ ¦ ¦ § § § ¨ ¨ ¨ © © © 
 51 ª ª ª « « « ¬ ¬ ¬ ­ ­ ­ ® ® ® 
 52 ¯ ¯ ¯ ° ° ° ± ± ± ² ² ² ³ ³ ³ 
 53 ´ ´ ´ µ µ µ ¶ ¶ ¶ · · · ¸ ¸ ¸ 
 54 ¹ ¹ ¹ º º º » » » ¼ ¼ ¼ ½ ½ ½ 
 55 ¾ ¾ ¾ ¿ ¿ ¿ À À À Á Á Á Â Â Â 
 56 Ã Ã Ã Ä Ä Ä Å Å Å Æ Æ Æ Ç Ç Ç 
 57 È È È É É É Ê Ê Ê Ë Ë Ë Ì Ì Ì 
 58 Í Í Í Î Î Î Ï Ï Ï Ð Ð Ð Ñ Ñ Ñ 
 59 Ò Ò Ò Ó Ó Ó Ô Ô Ô Õ Õ Õ Ö Ö Ö 
 60 × × × Ø Ø Ø Ù Ù Ù Ú Ú Ú Û Û Û 
 61 Ü Ü Ü Ý Ý Ý Þ Þ Þ ß ß ß à à à 
 62 á á á â â â ã ã ã ä ä ä å å å 
 63 æ æ æ ç ç ç è è è é é é ê ê ê 
 64 ë ë ë ì ì ì í í í î î î ï ï ï 
 65 ð ð ð ñ ñ ñ ò ò ò ó ó ó ô ô ô 
 66 õ õ õ ö ö ö ÷ ÷ ÷ ø ø ø ù ù ù 
 67 ú ú ú û û û ü ü ü ý ý ý þ þ þ 
 68 ÿ ÿ ÿ 
 69 
 70 数学和希腊字母标志
 71 symbols, mathematical symbols, and Greek letters
 72 显示 名称 编号 显示 名称 编号 显示 名称 编号 显示 名称 编号 显示 名称 编号 
 73 ƒ ƒ ƒ Α Α Α Β Β Β Γ Γ Γ Δ Δ Δ 
 74 Ε Ε Ε Ζ Ζ Ζ Η Η Η Θ Θ Θ Ι Ι Ι 
 75 Κ Κ Κ Λ Λ Λ Μ Μ Μ Ν Ν Ν Ξ Ξ Ξ 
 76 Ο Ο Ο Π Π Π Ρ Ρ Ρ Σ Σ Σ Τ Τ Τ 
 77 Υ Υ Υ Φ Φ Φ Χ Χ Χ Ψ Ψ Ψ Ω Ω Ω 
 78 α α α β β β γ γ γ δ δ δ ε ε ε 
 79 ζ ζ ζ η η η θ θ θ ι ι ι κ κ κ 
 80 λ λ λ μ μ μ ν ν ν ξ ξ ξ ο ο ο 
 81 π π π ρ ρ ρ ς ς ς σ σ σ τ τ τ 
 82 υ υ υ φ φ φ χ χ χ ψ ψ ψ ω ω ω 
 83 ? ϑ ϑ ? ϒ ϒ ? ϖ ϖ • • • … … … 
 84 ′ ′ ′ ″ ″ ″ ‾ ‾ ‾ ⁄ ⁄ ⁄ ℘ ℘ ℘ 
 85 ℑ ℑ ℑ ℜ ℜ ℜ ™ ™ ™ ℵ ℵ ℵ ← ← ← 
 86 ↑ ↑ ↑ → → → ↓ ↓ ↓ ↔ ↔ ↔ ↵ ↵ ↵ 
 87 ⇐ ⇐ ⇐ ⇑ ⇑ ⇑ ⇒ ⇒ ⇒ ⇓ ⇓ ⇓ ⇔ ⇔ ⇔ 
 88 ∀ ∀ ∀ ∂ ∂ ∂ ∃ ∃ ∃ ∅ ∅ ∅ ∇ ∇ ∇ 
 89 ∈ ∈ ∈ ∉ ∉ ∉ ∋ ∋ ∋ ∏ ∏ ∏ ∑ ∑ ∑ 
 90 − − − ∗ ∗ ∗ √ √ √ ∝ ∝ ∝ ∞ ∞ ∞ 
 91 ∠ ∠ ∠ ∧ ∧ ∧ ∨ ∨ ∨ ∩ ∩ ∩ ∪ ∪ ∪ 
 92 ∫ ∫ ∫ ∴ ∴ ∴ ∼ ∼ ∼ ∝ ≅ ≅ ≈ ≈ ≈ 
 93 ≠ ≠ ≠ ≡ ≡ ≡ ≤ ≤ ≤ ≥ ≥ ≥ ⊂ ⊂ ⊂ 
 94 ⊃ ⊃ ⊃ ⊄ ⊄ ⊄ ⊆ ⊆ ⊆ ⊇ ⊇ ⊇ ⊕ ⊕ ⊕ 
 95 ⊗ ⊗ ⊗ ⊥ ⊥ ⊥ ⋅ ⋅ ⋅ ? ⌈ ⌈ ? ⌉ ⌉ 
 96 ? ⌊ ⌊ ? ⌋ ⌋ ? ⟨ 〈 ? ⟩ 〉 ◊ ◊ ◊ 
 97 ♠ ♠ ♠ ♣ ♣ ♣ ♥ ♥ ♥ ♦ ♦ ♦ 
 98 
 99 重要的国际标记
100 markup-significant and internationalization characters
101 显示 名称 编号 显示 名称 编号 显示 名称 编号 显示 名称 编号 显示 名称 编号 
102 " " " & & & < < < > > > Œ Œ Œ 
103 œ œ œ Š Š Š š š š Ÿ Ÿ Ÿ ˆ ˆ ˆ 
104 ˜ ˜ ˜                      
105    ‎ ‎ ‎ ‏ ‏ ‏ – – – — — — 
106 ‘ ‘ ‘ ’ ’ ’ ‚ ‚ ‚ “ “ “ ” ” ” 
107 „ „ „ † † † ‡ ‡ ‡ ‰ ‰ ‰ ‹ ‹ ‹ 
108 › › › € € € 
109 
110 --------------------------------------------------------------------------------
111 
112 JavaScript转义符
113 转义序列 字符 
114 \b 退格 
115 \f 走纸换页 
116 \n 换行 
117 \r 回车 
118 \t 横向跳格 (Ctrl-I) 
119 \' 单引号 
120 \" 双引号 
121 \\ 反斜杠 
122 
123 编程的时候要注意特殊字符的问题,很多运行时出现的问题都是因为特殊字符的出现而引起的。 
124 
125 注意,由于反斜杠本身用作转义符,因此不能直接在脚本中键入一个反斜杠。如果要产生一个反斜杠,必须一起键入两个反斜杠 (\\)。 
126 
127 --------------------------------------------------------------------------------
128 
129 
130 编码转换(to Unicode)
131 (程序代码来源于网络) 
132 
133 
134 Js版 
135 
136 <script>
137      test = "你好abc"
138      str = ""
139      for( i=0;    i<test.length; i++ )
140      {
141       temp = test.charCodeAt(i).toString(16);
142       str    += "\\u"+ new Array(5-String(temp).length).join("0") +temp;
143      }
144      document.write (str)
145 </script>
146 
147 
148 vbs版
149 
150 
151 
152 Function Unicode(str1)
153      Dim str,temp
154      str = ""
155      For i=1    to len(str1)
156       temp = Hex(AscW(Mid(str1,i,1)))
157       If len(temp) < 5 Then    temp = right("0000" & temp, 4)
158       str = str & "\u" & temp
159      Next
160      Unicode = str
161 End Function
162 
163 
164 
165 Function htmlentities(str)
166      For i = 1 to Len(str)
167          char = mid(str, i, 1)
168          If Ascw(char) > 128 then
169              htmlentities = htmlentities & "&#" & Ascw(char) & ";"
170          Else
171              htmlentities = htmlentities & char
172          End if
173      Next
174 End Function
175 
176 coldfusion版
177 
178 
179 function nochaoscode(str)
180 {
181      var new_str = “”;
182      for(i=1; i lte len(str);i=i+1){
183          if(asc(mid(str,i,1)) lt 128){
184              new_str = new_str & mid(str,i,1);
185          }else{
186              new_str = new_str & “&##” & asc(mid(str,i,1));
187          }
188      }
189      return new_str;
190 }
191 
192 --------------------------------------------------------------------------------
193 
194 
195 附:
196 
197 在php中我们可以用mbstring的mb_convert_encoding函数实现这个正向及反向的转化。 如:
198 
199 
200 
201 
202 mb_convert_encoding ("你好", "HTML-ENTITIES", "gb2312"); //输出:你好 
203 
204 mb_convert_encoding ("你好", "gb2312", "HTML-ENTITIES"); //输出:你好 
205 
206 
207 如果需要对整个页面转化,则只需要在php文件的头部加上这三行代码:
208 
209 
210 mb_internal_encoding("gb2312"); // 这里的gb2312是你网站原来的编码 
211 
212 mb_http_output("HTML-ENTITIES"); 
213 
214 ob_start('mb_output_handler');