zoukankan      html  css  js  c++  java
  • CSS技巧(二):CSS hack

    摘自: http://www.cnblogs.com/ForEvErNoME/p/3385153.html 

    什么是CSS hack

    CSS hack由于不同的浏览器,比如IE6,IE7,Firefox等,对CSS的解析认识不一样,因此会导致生成的页面效果不一样,得不到我们所需要的页面效果。 这个时候我们就需要针对不同的浏览器去写不同的CSS,让它能够同时兼容不同的浏览器,能在不同的浏览器中也能得到我们想要的页面效果。

    CSS hack分类

    hack主要分为CSS选择器hack、CSS属性hack、IE条件注释hack。

    CSS选择器hack:比如 IE6能识别*html .class{},IE7能识别*+html .class{}或者*:first-child+html .class{}等。

    CSS属性hack:比如 IE6能识别下划线"_"和星号" * ",IE7能识别星号" * ",但不能识别下划线"_",而firefox两个都不能认识等。

    IE条件注释hack:

    针对所有IE:<!--[if IE]><!--您的代码--><![endif]-->

    针对IE6及以下版本:<!--[if lt IE 7]><!--您的代码--><![endif]-->

    这类Hack不仅对CSS生效,对写在判断语句里面的所有代码都会生效。

    书写顺序,一般是将识别能力强的浏览器的CSS写在前面。

    用法

    比如要分辨IE6和firefox两种浏览器,可以这样写:

    div{
    background:green; /* for firefox */
    *background:red; /* for IE6 */ (both IE6 && IE7)
    }

    可以看到在IE6中看到是红色的,在firefox中看到是绿色的。

    在firefox中,它是识别不了后面的那个带星号的东西是什么的,于是将它过滤掉,解析得到的结果是:div{background:green},于是理所当然这个div的背景是绿色的。
    在IE6中,它两个background都能识别出来,它解析得到的结果是:div{background:green;background:red;},于是根据优先级别,处在后面的red的优先级高,于是当然这个div的背景颜色就是红色的了。
     
    浏览器识别
    复制代码
    <!DOCTYPE html>  
    
    <html>  
    <head>  
        <title>Css Hack</title>  
        <style>  
        #test   
        {   
    
            300px;   
            height:300px;             
            background-color:blue;      /*firefox*/
            background-color:red9;      /*all ie*/
            background-color:yellow;    /*ie8*/
            +background-color:pink;        /*ie7*/
            _background-color:orange;       /*ie6*/
        }  
    
        :root #test { background-color:purple9; }  /*ie9*/
        @media all and (min-0px){ #test {background-color:black;} }  /*opera*/
        @media screen and (-webkit-min-device-pixel-ratio:0){ #test {background-color:gray;} }  /*chrome and safari*/
        </style>  
    </head>  
    <body>  
        <div id="test">test</div>  
    </body>  
    </html>
    复制代码

    上面这段代码大家可以直接copy出来,保存成html在各浏览器试试。分析:
    (1) 各个浏览器都认识,这里给firefox用;
    (2)background-color:red9; 9所有的ie浏览器可识别;
    (3) 是留给ie8的,但笔者测试,发现最新版opera也认识,汗。。。不过且慢,后面自有hack写了给opera认的,所以,我们就认为是给ie8留的;
    (4)+background-color:pink; + ie7定了;
    (5)_ _专门留给神奇的ie6;
    (6):root #test { background-color:purple9; } :root是给ie9的,网上流传了个版本是 :root #test { background-color:purple;},新版opera也认识,所以经笔者反复验证最终ie9特有的为:root 选择符 {属性9;}
    (7)@media all and (min-0px){ #test {} } 这个是老是跟ie抢着认的神奇的opera,必须加个,不然firefox,chrome,safari也都认识。。。
    (8)@media screen and (-webkit-min-device-pixel-ratio:0){ #test {background-color:gray;} }最后这个是浏览器新贵chrome和safari的。

    浏览器CSS hack
    IE6 _
    IE67 *
    IE67 +
    IE67 #
    IE67  
    IE678910  
    IE78910&Firefox&Opera&Chrome&Safari html>body .ie78910-all-hack 
    { padding: 0px;">
    IE8910&Firefox&Opera&Chrome&Safari html>/**/body .ie8910-all-hack
    { padding: 0px;">
    IE8910&Opera  
    IE910 :root .ie910-hack 
    { }
    IE910  
    IE910&Firefox&Opera&Chrome&Safari body:nth-of-type(1) .ie910-all-hack
    {}
    IE910&Firefox&Opera&Chrome&Safari @media all and (min- 0px)
    { .ie910-all-2-hack{ } }
    IE910&Firefox&Opera&Chrome&Safari @media all and (min- 0px)
    { .ie910-all-3-hack{} }
    IE910&Firefox&Opera&Chrome&Safari :root *> .ie910-all-4-hack
    { padding: 0px;">
    IE10 @media screen and (-ms-high-contrast: active),
    (-ms-high-contrast: none) 
    { .ie10-hack{} }
    Firefox @-moz-document url-prefix()
    { .firefox-hack{} }
    Chrome&Safari @media screen and (-webkit-min-device-pixel-ratio:0) 
    {.chrome-safari-hack{} }
     
  • 相关阅读:
    leetcode 1 Two sum
    hdu1099
    hdu1098
    函数执行顺序
    浏览器滚动条
    2048的制作
    JavaScript--对象-检查一个对象是否是数组
    JavaScript--格式化当前时间
    JavaScript--模拟验证码
    JavaScript--模拟网络爬虫
  • 原文地址:https://www.cnblogs.com/facial/p/5700336.html
Copyright © 2011-2022 走看看