1.區(qū)別IE和非IE瀏覽器
tip {
background:blue; /非IE 背景藍(lán)色/
background:red \9; /IE6狱意、IE7、IE8背景紅色/
background-color:red\0; / ie 8/9/
background-color:blue\9\0; / ie 9/
}
2.區(qū)別IE6,IE7,IE8,FF
【區(qū)別符號(hào)】:「\9」拯欧、「*」详囤、「_」、「\0」
【示例】:
tip {
background:blue; /Firefox 背景變藍(lán)色/
background-color:red\0; / ie 8/9/ /IE8 背景變紅色/
background-color:yellow\9\0; / ie 9/ /IE9 背景變黃色/
background:black; /IE7 背景變黑色/
background:orange; /IE6 背景變橘色/
}
【說(shuō)明】:因?yàn)镮E系列瀏覽器可讀「\9」镐作,而IE6和IE7可讀「」(米字號(hào))藏姐,另外IE6可辨識(shí)「」(底線),因此可以依照順序?qū)懴聛?lái)该贾,就 會(huì)讓瀏 覽器正確的讀取到自己看得懂得CSS語(yǔ)法羔杨,所以就可以有效區(qū)分IE各版本和非IE瀏覽器(像是Firefox、Opera杨蛋、Google Chrome兜材、Safari等)。
3.區(qū)別IE6逞力、IE7曙寡、Firefox (方法 1)
【區(qū)別符號(hào)】:「*」、「_」
【示例】:
tip {
background:blue; /Firefox背景變藍(lán)色/
background:black; /IE7 背景變黑色/
background:orange; /IE6 背景變橘色/
}
【說(shuō)明】:IE7和IE6可讀「」(米字號(hào))寇荧,IE6又可以讀「」(底線)举庶,但是IE7卻無(wú)法讀取「」,至于Firefox(非IE瀏覽器) 則完全 無(wú)法辨識(shí)「*」和「」揩抡,因此就可以透過(guò)這樣的差異性來(lái)區(qū)分IE6户侥、IE7镀琉、Firefox
4.區(qū)別IE6、IE7蕊唐、Firefox (方法 2)
【區(qū)別符號(hào)】:「*」屋摔、「!important」
【示例】:
tip {
background:blue; /Firefox 背景變藍(lán)色/
background:green !important; /IE7 背景變綠色/
background:orange; /IE6 背景變橘色/
}
【說(shuō)明】:IE7可以辨識(shí)「」和「!important」,但是IE6只可以辨識(shí)「」替梨,卻無(wú)法辨識(shí)「!important」凡壤,至于 Firefox可以 讀取「!important」但不能辨識(shí)「*」因此可以透過(guò)這樣的差異來(lái)有效區(qū)隔IE6、IE7耙替、Firefox。
5.區(qū)別IE7曹体、Firefox
【區(qū)別符號(hào)】:「*」俗扇、「!important」
【示例】:
tip {
background:blue; /Firefox 背景變藍(lán)色/
background:green !important; /IE7 背景變綠色/
}
【說(shuō)明】:因?yàn)镕irefox可以辨識(shí)「!important」但卻無(wú)法辨識(shí)「」,而IE7則可以同時(shí)看懂「*」箕别、「!important」铜幽,因 此可以 兩個(gè)辨識(shí)符號(hào)來(lái)區(qū)隔IE7和Firefox。
6.區(qū)別IE6串稀、IE7 (方法 1)
【區(qū)別符號(hào)】:「*」除抛、「_」
【示例】:
tip {
background:black; /IE7 背景變黑色/
_background:orange; /IE6 背景變橘色/
}
【說(shuō)明】:IE7和IE6都可以辨識(shí)「」(米字號(hào)),但I(xiàn)E6可以辨識(shí)「」(底線)母截,IE7卻無(wú)法辨識(shí)到忽,透過(guò)IE7無(wú)法讀取「」的特性就能輕 鬆區(qū)隔 IE6和IE7之間的差異。
7.區(qū)別IE6清寇、IE7 (方法 2)
【區(qū)別符號(hào)】:「!important」
【示例】:
tip {
background:black !important; /IE7 背景變黑色/
background:orange; /IE6 背景變橘色/
}
【說(shuō)明】:因?yàn)镮E7可讀取「!important;」但I(xiàn)E6卻不行喘漏,而CSS的讀取步驟是從上到下,因此IE6讀取時(shí)因無(wú)法辨識(shí) 「!important」而直接跳到下一行讀取CSS华烟,所以背景色會(huì)呈現(xiàn)橘色翩迈。
8.區(qū)別IE6、Firefox
【區(qū)別符號(hào)】:「_」
【示例】:
tip {
background:black; /Firefox 背景變黑色/
background:orange; /IE6 背景變橘色/
}
【說(shuō)明】:因?yàn)镮E6可以辨識(shí)「」(底線)盔夜,但是Firefox卻不行负饲,因此可以透過(guò)這樣的差異來(lái)區(qū)隔Firefox和IE6,有效達(dá)成CSS hack喂链。
9.區(qū)別IE8返十、IE9
一般來(lái)說(shuō),我們寫(xiě)的結(jié)構(gòu)比較好的時(shí)候,IE8/9下是沒(méi)區(qū)別的.所以可能很少人關(guān)注只有IE8或只有IE9才識(shí)別的css hack.
因?yàn)镮E8及以下版本是不支持CSS3的,但是我們?nèi)绻褂胏ss3,在IE下IE9正常渲染,但我們又想讓IE8及以下的瀏覽器實(shí)現(xiàn)同樣的效果,且不希望使用css3pie或htc或條件注釋等方法時(shí),可能就會(huì)需要用到IE8和IE9的專屬css hack了.
.test{
color:#09F\0; / IE8/9 /
color:#09F\0/; / IE8 only /
}
:root .test { color:#963\9; } / IE9 only /
/或者下面的,但是下面的優(yōu)先級(jí)小于上面的椭微。Ps:老外的方法都是\0吧慢,根本沒(méi)考慮Opera/
@media all and (min-width:0){
.test{color:red\9; }/ IE9 only /
}