当前位置: 首页 > 图文教程 > 网页制作 > HTML/XHTML教程 > ie7打开页面有源文件但页面空白问题的解决方法

HTML/XHTML教程
Xhtml第11天:如何制作不用表格的菜单
Xhtml第3天:定义语言编码
Xhtml第2天:什么是名字空间
CSS滤镜之Wave属性
CSS滤镜之Chroma属性
(译)用CSS设计日历
CSS滤镜之Shadow属性
CSS滤镜之Glow属性
CSS滤镜之Mask属性
在网页中实现细线边框的两种方法
背景音乐是如何插入的?
CSS 标签属性/属性参考
弹出网页窗口全攻略(html/hta)
五彩缤纷建网页(1)
五彩缤纷建网页(2)色彩的基本知识
五彩缤纷建网页(4)背景与字体的搭配经验
五彩缤纷建网页(3)色彩的象征
精通 CSS 滤镜(四)
精通 CSS 滤镜(三)
XHTML代码规范

HTML/XHTML教程 中的 ie7打开页面有源文件但页面空白问题的解决方法


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-11   浏览: 305 ::
收藏到网摘: n/a

问题:
我博客编码是utf-8的。有时候打开页面是一片空白,刷新一下又正常了,但查看源文件又是完整的。在ie6和firefox下都正常,但是在ie7下偶尔会出现这样的情况。
一开始我怀疑是IDC的问题,后来又想到了js、css、页面结构等。偶然间我想到了编码。毕竟编码的问题已经不是一两次找过我麻烦了。
解决:
<title>软晨学习网</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
交换一下顺序
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>LC'BLOG</title>
原因:
为什么只有ie7会出现这样的问题呢?这是由于ie7解析网页编码时以html内的标签优先,而后才是http header内的讯息,而mozilla系列的浏览器则刚刚相反。
由于utf-8编码的页面为3个字节表示一个汉字,而普通的gb2313或big5是两个。页面输出时,由于上述原因,使浏览器解析、输出<title></title>的内容时,如果在</title>前有奇数个全角字符时,ie7把utf-8当作两个字节解析时出现半个汉字的情况,这时该半个汉字会和</title>的"<"结合成一个乱码字,导致ie7无法读完<title>部分,使整个页面为空百输出。而这个时候如果察看源文件的话,会发现实际上整个叶面全部已经输出了。
因此最简单的解决办法是在网页文件的<head></head>标签中一定要把字符定义<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />放在<title></title>之前。
实际上,其他编码版本的也存在类似的问题,只是我们大家的浏览器默认编码都是 GBK 所以更不容易被察觉罢了。