注意:使用本人原創文章請留言,轉帖請注明來源
最近使用Qt開發了一個詞典工具,伺服器傳回來的單詞音标是用html轉義字元标示的,在Qlabel或者QTextBrowser中顯示音标就成為問題,比如:change[tʃeindʒ]
伺服器傳過來的是[tʃeindʒ],一開始找到一個辦法,使用<font >[tʃeindʒ]</font>後,windows7下非常正常,程式經過xp使用者測試,轉義字元的音标顯示不出來,<span style='font-family:"MS Mincho";'>ʃ</span>大部分xp使用者顯示正常了,小部分使用者還是不行,弄的有點狼狽,把MS Mincho換成MS Gothic,所有xp使用者都正常了,上述方法中的字元集,是通過把音标粘貼進word,另存為html檔案,分析html代碼後得到的。
html轉義字元網站http://114.xixik.com/character/
HTML字元實體(Character Entities),轉義字元串(Escape Sequence)
為什麼要用轉義字元串?
HTML中<,>,&等有特殊含義(<,>,用于連結簽,&用于轉義),不能直接使用。這些符号是不顯示在我們最終看到的網頁裡的,那如果我們希望在網頁中顯示這些符号,該怎麼辦呢?
這就要說到HTML轉義字元串(Escape Sequence)了。
轉義字元串(Escape Sequence)也稱字元實體(Character Entity)。在HTML中,定義轉義字元串的原因有兩個:第一個原因是像“<”和“>”這類符号已經用來表示HTML标簽,是以就不能直接當作文本中的符号來使用。為了在HTML文檔中使用這些符号,就需要定義它的轉義字元串。當解釋程式遇到這類字元串時就把它解釋為真實的字元。在輸入轉義字元串時,要嚴格遵守字母大小寫的規則。第二個原因是,有些字元在ASCII字元集中沒有定義,是以需要使用轉義字元串來表示。
轉義字元串的組成
轉義字元串(Escape Sequence),即字元實體(Character Entity)分成三部分:第一部分是一個&符号,英文叫ampersand;第二部分是實體(Entity)名字或者是#加上實體(Entity)編号;第三部分是一個分号。
比如,要顯示小于号(<),就可以寫 < 或者 < 。
用實體(Entity)名字的好處是比較好了解,一看lt,大概就猜出是less than的意思,但是其劣勢在于并不是所有的浏覽器都支援最新的Entity名字。而實體(Entity)編号,各種浏覽器都能處理。
提示:實體名稱(Entity)是區分大小寫的。
備注:同一個符号,可以用“實體名稱”和“實體編号”兩種方式引用,“實體名稱”的優勢在于便于記憶,但不能保證所有的浏覽器都能順利識别它,而“實體編号”則沒有這種擔憂,但它實在不友善記憶。
如何顯示空格?
通常情況下,HTML會自動截去多餘的空格。不管你加多少空格,都被看做一個空格。比如你在兩個字之間加了10個空格,HTML會截去9個空格,隻保留一個。為了在網頁中增加空格,你可以使用 表示空格。
HTML特殊轉義字元清單
最常用的字元實體
Character Entities
顯示 | 說明 | 實體名稱 | 實體編号 |
---|---|---|---|
半方大的空白 |   |   | |
全方大的空白 |   |   | |
不斷行的空白格 |   | ||
< | 小于 | < | < |
> | 大于 | > | > |
& | &符号 | & | & |
" | 雙引号 | " | " |
© | 版權 | © | © |
® | 已注冊商标 | ® | ® |
™ | 商标(美國) | ™ | ™ |
× | 乘号 | × | × |
÷ | 除号 | ÷ | ÷ |
ISO 8859-1 (Latin-1)字元集
HTML 4.01 支援 ISO 8859-1 (Latin-1) 字元集。
備注:為了友善起見,以下表格中,“實體名稱”簡稱為“名稱”,“實體編号”簡稱為“編号”
顯示 | 名稱 | 編号 | 顯示 | 名稱 | 編号 | 顯示 | 名稱 | 編号 | 顯示 | 名稱 | 編号 | 顯示 | 名稱 | 編号 |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
  | ¡ | ¡ | ¡ | ¢ | ¢ | ¢ | £ | £ | £ | ¤ | ¤ | ¤ | ||
¥ | ¥ | ¥ | ¦ | ¦ | ¦ | § | § | § | ¨ | ¨ | ¨ | © | © | © |
ª | ª | ª | « | « | « | ¬ | ¬ | ¬ | ­ | ­ | ® | ® | ® | |
¯ | ¯ | ¯ | ° | ° | ° | ± | ± | ± | ² | ² | ² | ³ | ³ | ³ |
´ | ´ | ´ | µ | µ | µ | ¶ | ¶ | ¶ | · | · | · | ¸ | ¸ | ¸ |
¹ | ¹ | ¹ | º | º | º | » | » | » | ¼ | ¼ | ¼ | ½ | ½ | ½ |
¾ | ¾ | ¾ | ¿ | ¿ | ¿ | À | À | À | Á | Á | Á | Â | Â | Â |
à | à | à | Ä | Ä | Ä | Å | Å | Å | Æ | Æ | Æ | Ç | Ç | Ç |
È | È | È | É | É | É | Ê | Ê | Ê | Ë | Ë | Ë | Ì | Ì | Ì |
Í | Í | Í | Î | Î | Î | Ï | Ï | Ï | Ð | Ð | Ð | Ñ | Ñ | Ñ |
Ò | Ò | Ò | Ó | Ó | Ó | Ô | Ô | Ô | Õ | Õ | Õ | Ö | Ö | Ö |
× | × | × | Ø | Ø | Ø | Ù | Ù | Ù | Ú | Ú | Ú | Û | Û | Û |
Ü | Ü | Ü | Ý | Ý | Ý | Þ | Þ | Þ | ß | ß | ß | à | à | à |
á | á | á | â | â | â | ã | ã | ã | ä | ä | ä | å | å | å |
æ | æ | æ | ç | ç | ç | è | è | è | é | é | é | ê | ê | ê |
ë | ë | ë | ì | ì | ì | í | í | í | î | î | î | ï | ï | ï |
ð | ð | ð | ñ | ñ | ñ | ò | ò | ò | ó | ó | ó | ô | ô | ô |
õ | õ | õ | ö | ö | ö | ÷ | ÷ | ÷ | ø | ø | ø | ù | ù | ù |
ú | ú | ú | û | û | û | ü | ü | ü | ý | ý | ý | þ | þ | þ |
ÿ | ÿ | ÿ |
數學和希臘字母标志
symbols, mathematical symbols, and Greek letters
顯示 | 名稱 | 編号 | 顯示 | 名稱 | 編号 | 顯示 | 名稱 | 編号 | 顯示 | 名稱 | 編号 | 顯示 | 名稱 | 編号 |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
ƒ | ƒ | ƒ | Α | Α | Α | Β | Β | Β | Γ | Γ | Γ | Δ | Δ | Δ |
Ε | Ε | Ε | Ζ | Ζ | Ζ | Η | Η | Η | Θ | Θ | Θ | Ι | Ι | Ι |
Κ | Κ | Κ | Λ | Λ | Λ | Μ | Μ | Μ | Ν | Ν | Ν | Ξ | Ξ | Ξ |
Ο | Ο | Ο | Π | Π | Π | Ρ | Ρ | Ρ | Σ | Σ | Σ | Τ | Τ | Τ |
Υ | Υ | Υ | Φ | Φ | Φ | Χ | Χ | Χ | Ψ | Ψ | Ψ | Ω | Ω | Ω |
α | α | α | β | β | β | γ | γ | γ | δ | δ | δ | ε | ε | ε |
ζ | ζ | ζ | η | η | η | θ | θ | θ | ι | ι | ι | κ | κ | κ |
λ | λ | λ | μ | μ | μ | ν | ν | ν | ξ | ξ | ξ | ο | ο | ο |
π | π | π | ρ | ρ | ρ | ς | ς | ς | σ | σ | σ | τ | τ | τ |
υ | υ | υ | φ | φ | φ | χ | χ | χ | ψ | ψ | ψ | ω | ω | ω |
? | ϑ | ϑ | ? | ϒ | ϒ | ? | ϖ | ϖ | • | • | • | … | … | … |
′ | ′ | ′ | ″ | ″ | ″ | ‾ | ‾ | ‾ | ⁄ | ⁄ | ⁄ | ℘ | ℘ | ℘ |
ℑ | ℑ | ℑ | ℜ | ℜ | ℜ | ™ | ™ | ™ | ℵ | ℵ | ℵ | ← | ← | ← |
↑ | ↑ | ↑ | → | → | → | ↓ | ↓ | ↓ | ↔ | ↔ | ↔ | ↵ | ↵ | ↵ |
⇐ | ⇐ | ⇐ | ⇑ | ⇑ | ⇑ | ⇒ | ⇒ | ⇒ | ⇓ | ⇓ | ⇓ | ⇔ | ⇔ | ⇔ |
∀ | ∀ | ∀ | ∂ | ∂ | ∂ | ∃ | ∃ | ∃ | ∅ | ∅ | ∅ | ∇ | ∇ | ∇ |
∈ | ∈ | ∈ | ∉ | ∉ | ∉ | ∋ | ∋ | ∋ | ∏ | ∏ | ∏ | ∑ | ∑ | ∑ |
− | − | − | ∗ | ∗ | ∗ | √ | √ | √ | ∝ | ∝ | ∝ | ∞ | ∞ | ∞ |
∠ | ∠ | ∠ | ∧ | ∧ | ∧ | ∨ | ∨ | ∨ | ∩ | ∩ | ∩ | ∪ | ∪ | ∪ |
∫ | ∫ | ∫ | ∴ | ∴ | ∴ | ∼ | ∼ | ∼ | ∝ | ≅ | ≅ | ≈ | ≈ | ≈ |
≠ | ≠ | ≠ | ≡ | ≡ | ≡ | ≤ | ≤ | ≤ | ≥ | ≥ | ≥ | ⊂ | ⊂ | ⊂ |
⊃ | ⊃ | ⊃ | ⊄ | ⊄ | ⊄ | ⊆ | ⊆ | ⊆ | ⊇ | ⊇ | ⊇ | ⊕ | ⊕ | ⊕ |
⊗ | ⊗ | ⊗ | ⊥ | ⊥ | ⊥ | ⋅ | ⋅ | ⋅ | ? | ⌈ | ⌈ | ? | ⌉ | ⌉ |
? | ⌊ | ⌊ | ? | ⌋ | ⌋ | ? | ⟨ | 〈 | ? | ⟩ | 〉 | ◊ | ◊ | ◊ |
♠ | ♠ | ♠ | ♣ | ♣ | ♣ | ♥ | ♥ | ♥ | ♦ | ♦ | ♦ |
重要的國際标記
markup-significant and internationalization characters
顯示 | 名稱 | 編号 | 顯示 | 名稱 | 編号 | 顯示 | 名稱 | 編号 | 顯示 | 名稱 | 編号 | 顯示 | 名稱 | 編号 |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
" | " | " | & | & | & | < | < | < | > | > | > | Œ | Œ | Œ |
œ | œ | œ | Š | Š | Š | š | š | š | Ÿ | Ÿ | Ÿ | ˆ | ˆ | ˆ |
˜ | ˜ | ˜ |   |   |   |   |   |   | | ‌ | ‌ | |||
| ‍ | ‍ | | ‎ | ‎ | | ‏ | ‏ | – | – | – | — | — | — |
‘ | ‘ | ‘ | ’ | ’ | ’ | ‚ | ‚ | ‚ | “ | “ | “ | ” | ” | ” |
„ | „ | „ | † | † | † | ‡ | ‡ | ‡ | ‰ | ‰ | ‰ | ‹ | ‹ | ‹ |
› | › | › | € | € | € |
JavaScript轉義符
轉義序列 | 字元 |
---|---|
\b | 倒退 |
\f | 走紙換頁 |
\n | 換行 |
\r | 回車 |
\t | 橫向跳格 (Ctrl-I) |
\' | 單引号 |
\" | 雙引号 |
\\ | 反斜杠 |
程式設計的時候要注意特殊字元的問題,很多運作時出現的問題都是因為特殊字元的出現而引起的。
注意,由于反斜杠本身用作轉義符,是以不能直接在腳本中鍵入一個反斜杠。如果要産生一個反斜杠,必須一起鍵入兩個反斜杠 (\\)。
編碼轉換(to Unicode)
(程式代碼來源于網絡)
Js版
<script>
test = "你好abc"
str = ""
for( i=0; i<test.length; i++ )
{
temp = test.charCodeAt(i).toString(16);
str += "\\u"+ new Array(5-String(temp).length).join("0") +temp;
}
document.write (str)
</script>
vbs版
Function Unicode(str1)
Dim str,temp
str = ""
For i=1 to len(str1)
temp = Hex(AscW(Mid(str1,i,1)))
If len(temp) < 5 Then temp = right("0000" & temp, 4)
str = str & "\u" & temp
Next
Unicode = str
End Function
Function htmlentities(str)
For i = 1 to Len(str)
char = mid(str, i, 1)
If Ascw(char) > 128 then
htmlentities = htmlentities & "&#" & Ascw(char) & ";"
Else
htmlentities = htmlentities & char
End if
Next
End Function
coldfusion版
function nochaoscode(str)
{
var new_str = “”;
for(i=1; i lte len(str);i=i+1){
if(asc(mid(str,i,1)) lt 128){
new_str = new_str & mid(str,i,1);
}else{
new_str = new_str & “&##” & asc(mid(str,i,1));
}
}
return new_str;
}
附:
在php中我們可以用mbstring的mb_convert_encoding函數實作這個正向及反向的轉化。 如:
mb_convert_encoding ("你好", "HTML-ENTITIES", "gb2312"); //輸出:你好
mb_convert_encoding ("你好", "gb2312", "HTML-ENTITIES"); //輸出:你好
如果需要對整個頁面轉化,則隻需要在php檔案的頭部加上這三行代碼:
mb_internal_encoding("gb2312"); // 這裡的gb2312是你網站原來的編碼
mb_http_output("HTML-ENTITIES");
ob_start('mb_output_handler');