2.用firedebug發現 meta和link標記在body標簽里.

本機上wmap運行沒事, 送到遠程服務器上是IASP的服務, 會出現上述bug.

看了下源文件, 文本一樣的. 但保 " /> 日韩欧美亚洲v片,国产精品色网,久久久久久久999精品视频

色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

php生成的html meta和link標記在body標簽里 頂部有個空行

1.php中用smarty模板生成的html在瀏覽器中頂部有一空行.

2.用firedebug發現 meta和link標記在body標簽里.

本機上wmap運行沒事, 送到遠程服務器上是IASP的服務, 會出現上述bug.

看了下源文件, 文本一樣的. 但保存時提示編碼問題.估計是utf-8問題了.

在網上找了下, 是utf-8 BOM問題.

解決方法: 用UltraEdit32把smarty模板文件即引用的模板文件(如include的header,footer等文件)全另存為無BOM的utf-8文件.

其它補充說明:

頁面采用UTF8編碼,頭部和尾部用了模板包含文檔的method,結果頭部和尾部無端端各多出一個約10px的空行,什么也沒有。

  原因是全部采用utf8編碼,包含文檔的時候,最后的二進制流中包含了多次UTF8 BOM標記,IE不能正常解析包含多個UTF8 BOM 標記的頁面,直接替換成實際顯示的回車,這樣導致一個空行,而firefox卻沒有這個問題。

  故如果模板采用包含的method包含多個utf8文檔需要用ultraedit保存時另存為功能 選擇utf8 無bom格式保存即可。

  另外,如果中文頁面在html head標記中將title標記放在<meta http-equiv=”Content-type” Content=”text/html; Charset=UTF-8″ />前面會導致頁面空白。

  所以utf8頁面應該使用標準順序
復制代碼 代碼如下:
<meta http-equiv=”Content-type” Content=”text/html; Charset=UTF-8″ />
<meta http-equiv=”Content-language” Content=”zh-CN” />
<meta name=”robots” Content=”index,follow” />
<meta name=”keywords” Content=”" />
<meta name=”desCription” Content=”" />
<meta name=”rating” Content=”general” />
<meta name=”author” Content=”" />
<meta name=”Copyright” Content=”" />
<meta name=”generator” Content=”" />
<title></title>

BOM頭:/xEF/xBB/xBF,php腳本4、5尚對BOM無視,所以在解析前直接輸出。

對此 w3.org 標準 FAQ 中對此問題有一個專門的描述:

www.w3.org/International/questions/qa-utf8-bom

具體如下:

在UCS 編碼中有一個叫做”ZERO WIDTH NO-BREAK SPACE”的char,它的編碼是FEFF。而FFFE在UCS中是不存在的char,所以不應該出現在實際傳輸中。UCS規范建議我們在傳輸字節流前,先傳輸 char”ZERO WIDTH NO-BREAK SPACE”。這樣如果接收者收到FEFF,就表明這個字節流是Big-Endian的;如果收到FFFE,就表明這個字節流是Little- Endian的。因此char”ZERO WIDTH NO-BREAK SPACE”又被稱作BOM。

UTF-8不需要BOM來表明字節順序,但可以用BOM來表明編碼方式。char”ZERO WIDTH NO-BREAK SPACE”的UTF-8編碼是EF BB BF。所以如果接收者收到以EF BB BF開頭的字節流,就知道這是UTF-8編碼了。

Windows就是使用BOM來標記文本文檔的編碼方式的操作Systam: WindowsXP Professional , 缺省char集:中文

1) notepad : 可以自動識別出沒有帶 bom 的 utf-8 編碼格式文檔,但不可以控制保存文檔時是否添加 bom , 如果保存文檔,那么會統一添加 bom 。

2)editplus : 不能自動識別出沒有 bom 的 utf-8 編碼格式文檔,文檔保存時,選擇UTF-8 格式,不會在文檔頭寫上 BOM header.

3) UltraEdit : 對于char編碼的功能最為強大, 可以自動識別帶 bom 和不帶 bom 的 utf-8 文檔 (可以配置) ; 保存的時候可以通過配置選擇是否添加 bom.
(特別需要注意的是,保存一個新建立的文檔時,需要選擇另存為 utf-8 no bom 格式)

后來發現 Notepad ++ 也對于 utf-8 bom 支持比較好,推薦大家使用。

php技術php生成的html meta和link標記在body標簽里 頂部有個空行,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 青龙| 搜索| 贵定县| 保靖县| 寿光市| 甘德县| 盐山县| 竹溪县| 遂宁市| 新河县| 深泽县| 永兴县| 佛学| 锦屏县| 云阳县| 桓台县| 曲沃县| 九龙城区| 石狮市| 三明市| 庐江县| 隆安县| 红河县| 巴里| 鹤岗市| 阿拉善盟| 桃源县| 阿勒泰市| 元氏县| 南岸区| 泸水县| 兴业县| 桂东县| 龙口市| 临邑县| 行唐县| 松阳县| 姚安县| 亳州市| 南澳县| 景谷|