史上最全的css hack

转载 2013年12月04日 17:23:55

转自:http://www.cnblogs.com/wuqiang/archive/2011/08/23/2150240.html


在这个浏览器百花争鸣的时代,作为前端开发的我们为了我们漂亮的设计能适应各个浏览器可为煞费苦心,主要体现在javascript和css上面。javascript我这次就不谈了,先说说css。

      为了适应不同浏览器不同的版本(版本主要就ie来说),ie这朵奇葩现在我们要兼容6-9,它的10也快出来了。。。在ie下我们可以写条件注释来区分ie和其他浏览器,以及ie的版本,这些请大家自行google。这篇文章主要讨论的是css hack。下面废话补多说了,直接上代码
复制代码
<!DOCTYPE html>  
<html>  
<head>  
    
<title>Css Hack</title>  
    
<style>  
    #test   
    
{   
        width
:300px;   
        height
:300px;   
          
        background-color
:blue;      /*firefox*/
        background-color
:red\9;      /*all ie*/
        background-color
:yellow\0;    /*ie8*/
        +background-color
:pink;        /*ie7*/
        _background-color
:orange;       /*ie6*/
    
}  
    :root #test 
{ background-color:purple\9; }  /*ie9*/
    @media all and (min-width:0px)
{ #test {background-color:black\0;} }  /*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在各浏览器试试。下面我来分析下:
    background-color:blue; 各个浏览器都认识,这里给firefox用;
    background-color:red\9;\9所有的ie浏览器可识别;
    background-color:yellow\0; \0 是留给ie8的,但笔者测试,发现最新版opera也认识,汗。。。不过且慢,后面自有hack写了给opera认的,所以,\0我们就认为是给ie8留的;
    +background-color:pink; + ie7定了;
    _background-color:orange; _专门留给神奇的ie6;
    :root #test { background-color:purple\9; } :root是给ie9的,网上流传了个版本是 :root #test { background-color:purple\0;},呃。。。这个。。。,新版opera也认识,所以经笔者反复验证最终ie9特有的为:root 选择符 {属性\9;}
    @media all and (min-width:0px){ #test {background-color:black\0;} } 这个是老是跟ie抢着认\0的神奇的opera,必须加个\0,不然firefox,chrome,safari也都认识。。。
    @media screen and (-webkit-min-device-pixel-ratio:0){ #test {background-color:gray;} }最后这个是浏览器新贵chrome和safari的。

    好了就这么多了,特别注意以上顺序是不可以改变的。css hack虽然可以解决个浏览器之间css显示的差异问题,但是毕竟不符合W3C规范,我们平时写css最好是按照标准来,这样对我们以后维护也是大有好处的,实在不行再用。

    如果给位看官有更好的css hack写法或者本文有不妥之处,欢迎留言,第一次写文章,请轻砸。

史上最全的CSS样式整理

一 字体属性:(font) 大小 {font-size: x-large;}(特大)xx-small;(极小) 一般中文用不到,只要用数值就可以,单位:PX、PD 样式 {font-style: ob...
  • u012847940
  • u012847940
  • 2016年06月23日 14:03
  • 557

史上最全最常用的正则表达式-(基本够用值得收藏)

最常用的正则表达式很全面- 一、校验数字的表达式 二、校验字符的表达式 三、特殊需求表达式 。。。。。...
  • d1020965026
  • d1020965026
  • 2014年05月12日 14:11
  • 1637

CSS hack大全&详解(什么是CSS hack)

原文:http://www.kwstu.com/Admin/ViewArticle/201409011604277330 CSS hack大全&详解(什么是CSS hack) 1、什么是C...
  • liu_rong_fei
  • liu_rong_fei
  • 2016年06月01日 13:57
  • 471730

史上最全的CSS hack方式总结

做前端多年,虽然不是经常需要hack,但是我们经常会遇到各浏览器表现不一致的情况。基于此,某些情况我们会极不情愿的使用这个不太友好的方式来达到大家要求的页面表现。我个人是不太推荐使用hack的,要知道...
  • spokenInChina
  • spokenInChina
  • 2016年07月15日 09:00
  • 615

史上最全的CSS hack方式一览

什么是CSS hack 由于不同厂商的流览器或某浏览器的不同版本(如IE6-IE11,Firefox/Safari/Opera/Chrome等),对CSS的支持、解析不一样,导致在不同浏览器的环境中呈...
  • freshlover
  • freshlover
  • 2013年09月28日 15:57
  • 168885

【重磅推荐】34张史上最全IT架构师技术知识图谱

http://developer.51cto.com/art/201708/548757.htm 本文是笔者多年来积累和收集的知识技能图谱,小编极力推荐分享给身边的技术人儿,希望这份技术知识...
  • wuxiaobingandbob
  • wuxiaobingandbob
  • 2017年09月01日 16:48
  • 694

java集合史上最全

java集合是java基础的重点知识库,但是好多人都知识了解了解。并没有系统的进行深入研究,下面我们就来看看集合家族的全部成员。掌握下面等东西 Collection和Map (1)掌握Collec...
  • baidu_23086307
  • baidu_23086307
  • 2016年10月20日 10:30
  • 593

《史上最全CSS Hack方式一览》

做前端多年,虽然不是经常需要hack,但是我们经常会遇到各浏览器表现不一致的情况。基于此,某些情况我们会极不情愿的使用这个不太友好的方式来达到大家要求的页面表现。我个人是不太推荐使用hack的,要知道...
  • dl429
  • dl429
  • 2014年10月31日 10:09
  • 241

史上最全CSS Hack方式一览

做前端多年,虽然不是经常需要hack,但是我们经常会遇到各浏览器表现不一致的情况。基于此,某些情况我们会极不情愿的使用这个不太友好的方式来达到大家要求的页面表现。我个人是不太推荐使用hack的,要知道...
  • YFEI69
  • YFEI69
  • 2015年10月28日 09:21
  • 270

史上最全 前端开发面试问题及答案整理 http://segmentfault.com/blog/trigkit4/1190000002562454

https://github.com/hawx1993/Front-end-Interview-questions 本文旨在加深对前端知识点的理解,资料来源于网络,由本人(博客:http:/...
  • forlong401
  • forlong401
  • 2015年07月22日 19:38
  • 2365
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:史上最全的css hack
举报原因:
原因补充:

(最多只允许输入30个字)