當(dāng)前位置:
首頁 >
前端技术
> javascript
>内容正文
javascript
关于在页面中针对不同版本的IE浏览器实现不同的JS或者CSS样式
生活随笔
收集整理的這篇文章主要介紹了
关于在页面中针对不同版本的IE浏览器实现不同的JS或者CSS样式
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
一般會(huì)用到<!--[if IE]>這里是正常的html代碼<![endif]--> 條件注釋只能在windows Internet Explorer(以下簡(jiǎn)稱IE)下使用,因此我們可以通過條件注釋來為IE添加特別的指令。因?yàn)檫@只是IE瀏覽器支持的注釋。 1,條件注釋的基本結(jié)構(gòu)和HTML的注釋(<!-- -->)是一樣的。因此IE以外的瀏覽器將會(huì)把它們看作是普通的注釋而完全忽略它們。
2,IE將會(huì)根據(jù)if條件來判斷是否如解析普通的頁面內(nèi)容一樣解析條件注釋里的內(nèi)容。
3,條件注釋使用的是HTML的注釋結(jié)構(gòu),因此他們只能使用在HTML文件里,而不能在CSS文件中使用??墒褂萌缦麓a檢測(cè)當(dāng)前IE瀏覽器的版本(注意:在非IE瀏覽器中是看不到效果的)<!--[if IE]><h1>您正在使用IE瀏覽器</h1><!--[if IE 5]><h2>版本 5</h2><![endif]--><!--[if IE 5.0]><h2>版本 5.0</h2><![endif]--><!--[if IE 5.5]><h2>版本 5.5</h2><![endif]--><!--[if IE 6]><h2>版本 6</h2><![endif]--><!--[if IE 7]><h2>版本 7</h2><![endif]-->
<![endif]-->那如果當(dāng)前的瀏覽器是IE,但版本比IE5還低,該怎么辦呢,可以使用<!--[if ls IE 5]>,當(dāng)然,根據(jù)條件注釋只能在IE5+的環(huán)境之下,所以<!--[if ls IE 5]>根本不會(huì)被執(zhí)行。lte:就是Less than or equal to的簡(jiǎn)寫,也就是小于或等于的意思。lt :就是Less than的簡(jiǎn)寫,也就是小于的意思。gte:就是Greater than or equal to的簡(jiǎn)寫,也就是大于或等于的意思。gt :就是Greater than的簡(jiǎn)寫,也就是大于的意思。! :就是不等于的意思,跟javascript里的不等于判斷符相同Conditional comments屬于CSS hack? 條件判斷屬于CSS hack嗎?嚴(yán)格地說是屬于CSS hack。因?yàn)榫秃孟笃渌嬲腃SS hack一樣,它使得我們可以給一些瀏覽器賦予特殊的樣式,再則它不依賴于某個(gè)瀏覽器的BUG來控制另外一個(gè)瀏覽器(的樣式)。除此之外,條件判斷還能用來做一些超出CSS HACK范圍的事情(雖然這種情況很少發(fā)生)。因?yàn)闂l件判斷不依賴于某個(gè)瀏覽器的hack,而是一個(gè)經(jīng)過深思熟慮的特色功能,所以我相信它是可以被放心地使用的。當(dāng)然,其他瀏覽器也有可能支持條件判斷(到目前為止還沒有),但是看起來,他們應(yīng)該不會(huì)使用如<!--[if IE]>這樣的語法。應(yīng)該如何應(yīng)用條件注釋本文一開始就說明了,因?yàn)镮E各版本的瀏覽器對(duì)我們制作的WEB標(biāo)準(zhǔn)的頁面解釋不一樣,具體就是對(duì)CSS的解釋不同,我們?yōu)榱思嫒葸@些,可運(yùn)用條件注釋來各自定義,最終達(dá)到兼容的目的。比如:<!-- 默認(rèn)先調(diào)用css.css樣式表 -->
<link rel="stylesheet" type="text/css" href="css.css" /><!--[if IE 7]>
<!-- 如果IE瀏覽器版是7,調(diào)用ie7.css樣式表 -->
<link rel="stylesheet" type="text/css" href="ie7.css" />
<![endif]--><!--[if lte IE 6]>
<!-- 如果IE瀏覽器版本小于等于6,調(diào)用ie.css樣式表 -->
<link rel="stylesheet" type="text/css" href="ie.css" />
<![endif]-->這其中就區(qū)分了IE7和IE6向下的瀏覽器對(duì)CSS的執(zhí)行,達(dá)到兼容的目的。同時(shí),首行默認(rèn)的css.css還能與其他非IE瀏覽器實(shí)現(xiàn)兼容。注意:默認(rèn)的CSS樣式應(yīng)該位于HTML文檔的首行,進(jìn)行條件注釋判斷的所有內(nèi)容必須位于該默認(rèn)樣式之后。比如如下代碼,在IE瀏覽器下執(zhí)行顯示為紅色,而在非IE瀏覽器下顯示為黑色。如果把條件注釋判斷放在首行,則不能實(shí)現(xiàn)。該例題很能說明網(wǎng)頁對(duì)IE瀏覽器和非IE瀏覽器間的兼容性問題解決。<style type="text/css">
body{
background-color: #000;
}
</style>
<!--[if IE]>
<style type="text/css">
body{
background-color: #F00;
}
</style>
<![endif]-->同時(shí),有人會(huì)試圖使用<!--[if !IE]>來定義非IE瀏覽器下的狀況,但注意:條件注釋只有在IE瀏覽器下才能執(zhí)行,這個(gè)代碼在非IE瀏覽下非單不是執(zhí)行該條件下的定義,而是當(dāng)做注釋視而不見。正常就是默認(rèn)的樣式,對(duì)IE瀏覽器需要特殊處理的,才進(jìn)行條件注釋。
轉(zhuǎn)載于:https://www.cnblogs.com/wanghang/p/6298916.html
總結(jié)
以上是生活随笔為你收集整理的关于在页面中针对不同版本的IE浏览器实现不同的JS或者CSS样式的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 造影右侧输卵管通而不畅怎么办?如何治疗?
- 下一篇: ASP 调用dll(VB)及封装dll实