IE不能自動選擇UTF-8編碼解決方法
作者:Eve Cole
更新時間:2009-06-20 16:51:40
在Windows作業系統上使用IE作為瀏覽器時。常常會發生這樣的問題:在瀏覽使用UTF-8編碼的網頁時,瀏覽器無法自動偵測(即沒有設定「自動選擇」編碼格式時)該頁面所使用的編碼。即使網頁已經聲明過編碼格式:<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />,由此造成某些含有中文UTF-8編碼的頁面產生空白輸出。
如果使用的是Mozilla、Mozilla Firefox、Sarafi的瀏覽器這不會造成這個問題。這是由於IE解析網頁編碼時以HTML內的標籤優先,而後才是HTTP header內的訊息;而mozilla系列的瀏覽器則剛好相反。
由於UTF-8為3個位元組表示一個漢字,而普通的GB2312或BIG5是兩個。頁面輸出時,由於上述原因,使瀏覽器解析、輸出<title></title>的內容時,如果在</title>前有奇數個全角字符時,IE把UTF-8當作兩個字節解析時出現半個漢字的情況,這時該半個漢字會和</title>的<結合成一個亂碼字,導致IE無法讀完<title>部分,使整個頁為空百輸出。而這時候如果察看源文件的話,會發現實際上整個葉面都已經輸出了。
因此最簡單的解決方法是在網頁檔案的<head></head>標籤中一定要把字元定義<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" / >放在<title></title>之前。