HTML和CSS中判斷IE版本並實作對應HTML和CSS的詳細說明

高洛峰
發布: 2017-03-26 10:33:51
原創
1380 人瀏覽過

在编写网页代码时,各种浏览器的兼容性是个必须考虑的问题,有些时候无法找到适合所有浏览器的写法,就只能写根据浏览器种类区别的代码,这时就要用到判断代码了。

1.HTML代码中

经过本人测试,在HTML代码中,区别各种浏览器的代码如下:

<!--[if IE 6]> 仅支持IE6 <![endif]-->
<!--[if lte IE 6]> 支持IE5和IE6 <![endif]-->
<!--[if lt IE 6]> 支持IE5 <![endif]-->
<!--[if gte IE 6]> 支持IE6-IE9 <![endif]-->
<!--[if gt IE 6]> 支持IE7-IE9 <![endif]-->
<!--[if IE]> 支持IE5-IE9 <![endif]-->
<!--[if !IE]><!--> 支持IE9+,以及其他浏览器 <!--<![endif]-->
登入後複製

原理:针对不同版本的浏览器,这些代码都会被解释为Html注释而直接无视掉。

2.CSS代码中

CSS代码中,则可以根据各浏览器自己独立的可识别的特殊代码来编写区分浏览器的代码,例如为IE系列浏览器可读[\9],而IE6和IE7可读[*],另外IE6可辨识[ _ ](下划线);由
于CSS读取时是按从上到下来的,同样属性靠后写的生效,因此可以依照顺序写下来,就会让每个浏览器正确的读取到自己看得懂得CSS语法,有效区分各类型或版本:

    <style type="text/css">
        #element{ width:300px;height:100px;}
        #element{
            background:blue; /*IE9及以上,Firefox等非IE浏览器背景蓝色,如果删除后续样式,都会显示蓝色背景*/
            background:red \9; /*IE8 背景红色*/
            *background:black; /*IE7 背景黑色;如果删除此行和下一行样式,IE8以下也会显示红色*/
            _background:orange; /*IE5、IE6 背景橘色;如果删除这行样式,IE7以下也会显示黑色背景*/
        }
        #element {
            /* 其他浏览器可读取「!important;」但IE6及以下却不行 */
            border:5px solid green !important; /*非IE6 边框绿色*/
            border:5px solid yellow; /*IE5、IE6 边框黄色*/
        }
    </style>
登入後複製

PS:说起Web的界面,最让各位WEB开发者痛苦的就是网页兼容性问题,IE是一个恶梦,因为其自己和自己都不兼容,在MSDN上,有这样的一个网页说明了从IE5一直到IE9的CSS的兼容性问题 ,很多很多的表格,头都看大了。

以上是HTML和CSS中判斷IE版本並實作對應HTML和CSS的詳細說明的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板