• CSS中的!important属性用法


     由于IE并不严格执行W3C标准, 而又几乎垄断了浏览器市场。 所以作为一名合格的网站制作人员, 必须要针对不同的浏览器进行微调。 实现不同浏览器之间兼容的方法有很多, 比如利用JS探测用户的浏览器类型,从而调用不同的样式表。 或者就是利用!important 属性来实现微调的效果。 

     

    下面是一段普通的 DIV 代码:

    <div id="a"></div>

    下面是有关层A在CSS样式表中的定义, 注意,这里使用了!important这个属性。

    #a{margin-left:30px!important; margin-left:20px;}

    在上面的例子中, 层a 在IE浏览器中, 左边距为20像素, 而在Firefox中, 左边距则变为30像素。 这是因为, !important在 CSS 中表示优先调用, 由于IE不能够识别这个属性, 所以在IE中, 只能够调用 “margin-left:20px;" 这个选项, 所以同样的一段代码, 在Firefox和IE中就会显示不同的样式。

    不过值得注意的是, 最新版的IE 7.0 已经可以识别 !important, 这个属性了, 但是IE 6.0仍然不能识别。 所以这个小技巧还是相当有用的.

     

    可使用如下代码检测当前IE浏览器的版本(注意:在非IE浏览器中是看不到效果的),此方法用于IE5及以上版本。 

    HTML 的注释格式是 <!-- Comment content --> , IE 对HTML注释做了一些扩展,使之可以支持条件判断表达式: 
    <!--[if expression]> HTML <![endif]--> 当表达式expression 为True 的时候,显示 HTML 内容。 

     


    <!--[if IE]> You are using Internet Explorer. <![endif]-->
    <!--[if IE 7]> Welcome to Internet Explorer 7! <![endif]-->
    <!--[if !(IE 7)]> You are not using version 7. <![endif]-->
    <!--[if gte IE 7]> You are using IE 7 or greater. <![endif]-->
    <!--[if (IE 5)]> You are using IE 5 (any version). <![endif]-->
    <!--[if (gte IE 5.5)&(lt IE 7)]> You are using IE 5.5 or IE 6. <![endif]-->
    <!--[if lt IE 5.5]> Please upgrade your version of Internet Explorer. <![endif]-->

    (2)应该如何应用条件注释 

    因为IE各版本的浏览器对我们制作的WEB标准的页面解释不一样,具体就是对CSS的解释不同,我们为了兼容这些,可运用条件注释来各自定义,最终达到兼容的目的。 

    比如: < !–- 默认先调用css.css样式表 –-> 

    <link rel="stylesheet" type="text/css" href="css.css" />< !-–[if IE 7]> 

    <!–- 如果IE浏览器版是7,调用ie7.css样式表- –> 

    <link rel="stylesheet" type="text/css" href="ie7.css" />< ![endif]–-> 

    <!–-[if lte IE 6]> 

    <!–- 如果IE浏览器版本小于等于6,调用ie.css样式表 -–> 

    <link rel="stylesheet" type="text/css" href="ie.css" />< ![endif]–> 这其中就区分了IE7和IE6向下的浏览器对CSS的执行,达到兼容的目的。同时,首行默认的css.css还能与其他非IE浏览器实现兼容。 

    注意:默认的CSS样式应该位于HTML文档的首行,进行条件注释判断的所有内容必须位于该默认样式之后。 比如如下代码,在IE浏览器下执行显示为红色,而在非IE浏览器下显示为黑色。如果把条件注释判断放在首行,则不能实现。该例题很能说明网页对IE浏览器和非IE浏览器间的兼容性问题解决。 <style type="text/css"> body{ } < /style> < !-–[if IE]> 

    <style type="text/css">body{}< /style>< ![endif]–-> 

    同时,有人会试图使用<!–-[if !IE]>来定义非IE浏览器下的状况,但注意:条件注释只有在IE浏览器下才能执行,这个代码在非IE浏览下非单不是执行该条件下的定义,而是当做注释视而不见。 

    正常就是默认的样式,对IE浏览器需要特殊处理的,才进行条件注释。在HTML文件里,而不能在CSS文件中使用。 

    现在的DWcs4里面,已经装备了这些注释:在“窗口-->代码片段-->注释”里。其他的版本没太注意到。 

     

     

     

     

     

  • 相关阅读:
    任何时候都适用的20个C++技巧
    C++ 解析Json——jsoncpp(转)
    C++标准库和标准模板库(转)
    string标准C++中的的用法总结(转)
    JOIN US | 京东智联云诚聘技术精英
    在线公开课 | 云原生下的DevOps与持续交付
    AI端侧落地,京东AI技术如何部署边缘?
    CVPR 2020 | 京东AI研究院对视觉与语言的思考:从自洽、交互到共生
    IOT、AI、云计算等融合技术推进制造业产业转型
    边缘计算2.0时代,“云边缘”与“边缘云”你分清了吗?
  • 原文地址:https://www.cnblogs.com/zhaoleigege/p/4797387.html
Copyright © 2020-2023  润新知