• HTML和CSS中判断IE版本并实现相应HTML和CSS


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

    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的兼容性问题 ,很多很多的表格,头都看大了。

  • 相关阅读:
    剑指Offer
    剑指Offer
    ASP.NET MVC4中的bundles特性引发服务器拒绝访问(403错误)
    less文件的样式无法生效的一个原因,通过WEB浏览器访问服务器less文件地址返回404错误
    Sqlserver Sql Agent Job 只能同时有一个实例运行
    SSAS 聚合设计提升CUBE的查询性能(转载)
    SQL SERVER: 合并相关操作(Union,Except,Intersect)
    SQL Server安装完成后3个需要立即修改的配置选项(转载)
    收缩TempDB的办法(转载)
    SSIS 关于并发的两个设置
  • 原文地址:https://www.cnblogs.com/yc-755909659/p/6610566.html
Copyright © 2020-2023  润新知