亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 課堂 > 瀏覽器 > 正文

瀏覽器解析模式-DOCTYPE聲明問題用法詳解

2020-03-24 18:04:20
字體:
來源:轉載
供稿:網友
網頁制作cnn6文章簡介:IE8有4種模式:IE5.5怪異模式、IE7標準模式、IE8幾乎標準模式、IE8標準模式。

觸發標準模式

1、加DOCTYPE聲明,比如:

 !DOCTYPE html PUBLIC -//W3C//DTD XHTML 1.1//EN http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd  !DOCTYPE HTML PUBLIC -//W3C//DTD HTML 4.01//EN http://www.w3.org/TR/html4/strict.dtd  !DOCTYPE html 

2、設置X-UA-Compatible觸發。

觸發怪異模式

1、無doctype聲明、定義舊的HTML版本(HTML4以下,例如3.2)
2、加XML聲明,可在ie6下觸發
?xml version= 1.0 encoding= utf-8 ?
!DOCTYPE ...
3、在XML聲明和XHTML的DOCTYPE之間加入HTML注釋,可在ie7下觸發 ?xml version= 1.0 encoding= utf-8 ?
!-- keep IE7 in quirks mode --
!DOCTYPE ...
5、 !--- 放在 !DOCTYPE前面

IE8有4種模式:IE5.5怪異模式、IE7標準模式、IE8幾乎標準模式、IE8標準模式

X-UA-Compatible設置對IE8模式的影響:
1、設置X-UA-Compatible meta

IE=5、IE=6(介于5、6之間的任意數字,比如5.987654321):觸發IE5怪異模式(無論頁面是否有DOCTYPE)
IE=7(7 = 值 8):強制IE7標準(無論頁面是否有DOCTYPE)
IE=EmulateIE7:遵循DOCTYPE(有DOCTYPE-IE7標準;無DOCTYPE-IE5怪異模式)
IE=EmulateIE8:遵循DOCTYPE(DOCTYPE-IE8幾乎標準模式(或IE8標準模式);無DOCTYPE-IE5怪異模式)
IE=8、IE=Edge、IE=99、IE=9.9(大于等于8的):有doctype-使用幾乎標準模式,或IE8標準;無doctype-IE8標準。
無X-UA-Compatible、IE=IE8、IE=IE7、IE=a、把X-UA-Compatible寫在 link 或 script 標簽后:判斷 X-UA-Compatible HTTP Header 。

注1:把X-UA-Compatible寫在 link 或 script 標簽下面,X-UA-Compatible的設置無效。
注2:頁面、服務器HTTP Header都設置了X-UA-Compatible的情況,使用頁面的X-UA-Compatible設置。頁面無X-UA-Compatible,才使用HTTP Header設置的值。
注3:幾乎標準模式的意思和觸發,下面的 Almost Standards Mode 有說明。
注4:IE=xx的值,ie會嘗試xx轉換為最接近的值。比如:IE=7.789 - IE=7;介于5、6之間的- IE=5;大于等于8的- IE=8。
注5:IE=4、IE=3、IE=0.1、IE=-7 這些小于5的,包括類似IE=IE8、IE=IE7、IE=IE6、IE=a、IE=b、IE=bcd,和無X-UA-Compatible一樣一樣滴??梢岳斫鉃閄-UA-Compatible設置了無效的值,所以跳過這里了。

2、設置X-UA-Compatible HTTP Header

IE=5、IE=6: 觸發IE5怪異模式(無論頁面是否有DOCTYPE)
IE=7(7 = 值 8): 強制IE7標準(無論頁面是否有DOCTYPE)
IE=EmulateIE7: 遵循DOCTYPE(有DOCTYPE-IE7標準;無DOCTYPE-IE5怪異模式)
IE=EmulateIE8:遵循DOCTYPE(DOCTYPE-IE8幾乎標準,或IE8標準;無DOCTYPE-IE5怪異模式)
IE=8、IE=Edge、IE=99、IE=9.9(大于等于8的):有doctype-使用幾乎標準模式(或IE8標準);無doctype-IE8標準。
注:設置了X-UA-Compatible(meta或http header)后,會覆蓋客戶端兼容視圖設置。會強迫(優先)使用X-UA-Compatible設置的模式
無X-UA-Compatible、IE=IE8、IE=IE7、IE=a、還有上面注5里面提到的:首先判斷 兼容性視圖 ,有 兼容性視圖 的設置(doctype-IE7標準,無doctype-IE5怪異模式);未設置 兼容性視圖 ,有DOCTYPE-遵循doctype,無doctype-IE5怪異模式。

IE9有7種模式: IE5.5怪異模式、IE7標準模式、IE8幾乎標準模式、IE8標準模式、IE9幾乎標準模式、IE9標準模式、XML模式

IE9和IE8大體上差不多:
X-UA-Compatible
IE=(0 = 值 7) - 觸發怪異模式(無論頁面是否有DOCTYPE),注:這里的怪異模式和IE8下的有點不同,測試發現 - 、 _ 這兩個css hack符號,IE8怪異下是都識別的,IE9怪異下不識別 - 。
IE=7(7 = 值 8) - 強制IE7標準(無論頁面是否有DOCTYPE)
IE=8(8 = 值 9) - 強制IE8標準,有doctype-使用IE8幾乎標準模式(或IE8標準),無doctype-IE8標準
IE=EmulateIE7、EmulateIE8 和上面IE8的情況一樣
IE=9、IE=Edge(值 =9 ) - 有doctype-使用幾乎標準模式(或IE9標準)。和IE8一樣,靠doctype來選擇IE9幾乎標準,或IE9標準模式;無doctype-IE9標準。
IE=(值 0)、IE=IE8、IE=IE7、IE=IE6、IE=a、IE=b、IE=bcd、IE=xxx類似這樣不靠譜的、或把X-UA-Compatible meta寫在 link 或 script 標簽后的,這些情況和無X-UA-Compatible是一樣的:首先判斷 兼容性視圖 ,有 兼容性視圖 的設置(doctype-IE7標準,無doctype-怪異模式);未設置 兼容性視圖 ,有DOCTYPE-遵循doctype,無doctype-怪異模式。

X-UA-Compatible的特殊寫法

msdn上面提到了X-UA-Compatible值設置成 IE=9; IE=8; IE=5 這樣的,意思就是優先最前面的IE9,沒IE9就用IE8,沒IE8就IE5,并且并不推薦在生產環境下使用。
觸發Google Chrome Frame: meta http-equiv= X-UA-Compatible content= chrome=1
可以和IE的X-UA-Compatible混搭:比如: meta http-equiv= X-UA-Compatible content= IE=edge,chrome=1 。這樣寫的好處:可以讓ie在最好的渲染方式下渲染頁面。
IE=edge,chrome=1 ,可以寫成 chrome=1,IE=edge 、 chrome=1; IE=edge 。

幾乎標準模式(Almost Standards Mode)

Firefox 1+、Safari、Chrome、Opera(從7.5開始)和IE8/IE9增加了一個 幾乎標準模式 ,它實現傳統的表格單元格的垂直尺寸(沒有嚴格的遵照CSS2規范)。
意思就是,比如下面的代碼:

 table >

比如在IE7標準模式下,圖片底部和table是沒空白的; 幾乎標準模式 下,圖片底部和table也是沒空白的;而較新的瀏覽器在標準模式下圖片底部和table會有個空白。
@see:https://developer.mozilla.org/en/Images,_Tables,_and_Mysterious_Gaps

下面的DOCTYPE都可觸發IE8標準模式:

 !DOCTYPE html PUBLIC -//W3C//DTD XHTML 1.0 Strict//EN http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd  !DOCTYPE html PUBLIC -//W3C//DTD XHTML 1.1//EN http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd  !DOCTYPE HTML PUBLIC -//W3C//DTD HTML 4.01//EN http://www.w3.org/TR/html4/strict.dtd  !DOCTYPE html 

觸發IE8幾乎標準模式:
!DOCTYPE HTML PUBLIC -//W3C//DTD HTML 4.01 Transitional//EN http://www.w3.org/TR/html4/loose.dtd
!DOCTYPE HTML PUBLIC -//W3C//DTD HTML 4.01 Frameset//EN http://www.w3.org/TR/html4/frameset.dtd
Mac IE5、IE6/7、Opera( 7.5)和Konqueror無幾乎標準模式(它們沒有嚴格遵循CSS2規范,實際上,它們的標準模式更接近幾乎標準模式)。HTML5把這種模式叫“受限怪異模式(limited quirks mode)”。

XML模式 - application/xhtml+xml Content

Firefox、Safari、Chrome和Opera中,HTTP頭設置了MIME-type(Content-Type為application/xhtml+xml時),會觸發XML模式。在XML模式中,瀏覽器會嚴格地以XML解析XHTML文檔(很嚴格,用過W3C的xhtml驗證的同學應該明白,比如 要用 +"amp; 、
要用 br / )。
任何一個XHTML文檔的解析錯誤會導致停止解析,FF/SF/CH/OP會直接報XML解析錯誤,IE9可以在開發人員工具的console里面看到報錯。
MacIE5、IE6/7/8不支持application/xhtml+xml。
發現IE9下使用此模式,doctype是無所謂的, html xmlns= http://www.w3.org/1999/xhtml 這句命名空間必須的,沒設置命名空間css會以文本解析而失效。
同時XML模式下,X-UA-Compatible的設置將會無效。

總結:

X-UA-Compatible只有IE =8才識別,所以他們可以用doctype聲明、X-UA-Compatible、兼容性視圖設置來改變模式。
IE6/7卻依靠DOCTYPE來改變標準或怪異模式,類似這些低版本的瀏覽器下的標準模式,接近與“先進”瀏覽器下的幾乎標準模式,因為它們都沒有嚴格遵循CSS2規范。并且他們同樣在標準模式下,各自的渲染還是是有差別的。沒差別就不會有css hack的誕生。
IE6-IE9下,怪異模式都在IE5.5下。
不需要寫X-UA-Compatible,用css也完全可以搞定各個版本IE的解析不同。

模式、版本不同,不僅僅css解析不同,js的解析也有不同。
了解瀏覽器解析模式的不同,可以避免我們辛苦寫出的標準代碼被怪異所殘害。
讓開發者更注重遵循標準,無論在生產效率還是在協作、溝通上都有好處滴。
現在幾乎人人都用標準的doctype來聲明文檔,所以糾結標準、怪異模式對工作的影響不太大。

以上就是瀏覽器解析模式:DOCTYPE聲明問題用法詳解的詳細內容,html教程

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲va久久久噜噜噜久久天堂| 亚洲精品aⅴ中文字幕乱码| 亚洲国产精品va| 国产有码在线一区二区视频| 欧美精品久久久久久久久| 欧美日韩另类在线| 97欧美精品一区二区三区| 久久噜噜噜精品国产亚洲综合| 国产亚洲欧洲在线| 日日摸夜夜添一区| 热久久美女精品天天吊色| 精品一区二区三区电影| 亚洲国产精品人久久电影| 日韩性xxxx爱| 国产精品亚洲第一区| 91精品美女在线| 2018国产精品视频| 国产精品欧美在线| 97久久精品在线| 欧美视频第一页| 国产精品入口免费视| 日韩福利伦理影院免费| 国产国产精品人在线视| 最近2019中文字幕一页二页| 国产精品久久久久久久久久久久久久| 97久久久久久| 亚洲一区二区三区在线免费观看| 日本精品视频在线观看| 国产精品视频成人| 青草青草久热精品视频在线网站| 国产精品一香蕉国产线看观看| 色偷偷888欧美精品久久久| 2020欧美日韩在线视频| 大桥未久av一区二区三区| 久久99青青精品免费观看| xvideos国产精品| 欧美男插女视频| 国产日韩欧美影视| 国产主播喷水一区二区| 成人免费网站在线观看| 国产精品av在线播放| 国产精品自拍偷拍| 亚洲欧洲视频在线| 一本大道久久加勒比香蕉| 日韩在线视频国产| 精品一区二区三区四区在线| 国产精品高潮呻吟久久av野狼| 成人午夜小视频| 992tv成人免费影院| 一区二区av在线| 亚洲精品在线不卡| 91成人天堂久久成人| 欧美视频一区二区三区…| 免费99精品国产自在在线| 日韩动漫免费观看电视剧高清| 久久久久久久999| 国产精品天天狠天天看| 久久久综合免费视频| 国产一区二区三区在线观看视频| 97超级碰在线看视频免费在线看| 国产亚洲精品久久久久久牛牛| 欧美精品成人91久久久久久久| 国产成人精品亚洲精品| 欧美精品免费播放| 亚洲国产福利在线| 最近中文字幕2019免费| 亚洲综合精品一区二区| 亚洲成色777777女色窝| 青草青草久热精品视频在线观看| 日韩网站免费观看高清| 97在线精品国自产拍中文| 国产+成+人+亚洲欧洲| 欧美一区二区视频97| 国产在线观看91精品一区| 国产精品国语对白| 亚州精品天堂中文字幕| 欧洲亚洲免费在线| 国产亚洲精品久久久久久777| 日韩福利视频在线观看| 国产精品wwww| 欧美一区二区三区……| 欧美另类极品videosbest最新版本| 国产日产久久高清欧美一区| 国产一区二区三区在线观看网站| 久久久精品免费视频| 国产这里只有精品| 精品久久国产精品| 久久精品在线视频| 久久精品亚洲精品| 亚洲国产精品久久91精品| 亚洲成人av资源网| 久久久久久久久中文字幕| 日韩美女av在线免费观看| 777国产偷窥盗摄精品视频| 欧美大尺度电影在线观看| 中文字幕日韩视频| 国产成人欧美在线观看| 九九热精品视频在线播放| 国产精品精品视频一区二区三区| 欧美精品videosex性欧美| 亚洲人成电影在线播放| 国内精品在线一区| 国内精品模特av私拍在线观看| 亚洲国产成人久久综合| 日韩中文字幕视频在线观看| 日韩理论片久久| 亚洲欧美日韩中文在线| 日本成人黄色片| 亚洲欧洲午夜一线一品| 国产精品96久久久久久又黄又硬| 91欧美视频网站| 亚洲日本成人女熟在线观看| 欧美巨乳美女视频| 国产视频在线一区二区| 亚洲美女在线观看| 国语自产精品视频在免费| 国产伦精品一区二区三区精品视频| 国产精品69久久| 欧美亚州一区二区三区| 91老司机精品视频| 日韩av在线影院| 黄色精品在线看| 国产精品国产三级国产专播精品人| 91在线视频免费| 国产丝袜精品视频| 青青青国产精品一区二区| 亚洲成人av片在线观看| 日韩免费精品视频| 久久久女人电视剧免费播放下载| 欧美激情综合色综合啪啪五月| 亚洲激情视频网站| 亚洲欧美制服丝袜| 国产精品欧美一区二区| 不卡中文字幕av| 国产精品免费一区豆花| 88国产精品欧美一区二区三区| 日韩精品在线播放| 久久国产精品首页| 韩国欧美亚洲国产| 国产香蕉97碰碰久久人人| 日韩成人中文字幕| 日韩极品精品视频免费观看| 欧美影院成年免费版| 成人高清视频观看www| 国产999视频| 色久欧美在线视频观看| 欧美日韩xxx| 国产一区二区三区在线观看网站| 欧洲亚洲妇女av| 色偷偷88888欧美精品久久久| 中文字幕日韩精品在线观看| 中文字幕国产精品| 日韩av网站大全| 久久久久久久久久国产| 久久久久久久国产| 美女啪啪无遮挡免费久久网站| 国产精品自产拍在线观看中文| 日韩经典第一页| 欧美日韩另类在线| 日韩av最新在线观看| 欧美成人午夜激情| 最近2019中文字幕一页二页| 欧美一级成年大片在线观看| 在线观看欧美视频|