hack是主要来处理IE的兼容,不同的IE,不同的兼容方式

/*
  属性前缀法(即类内部Hack):
   
  *color:#000; *号对IE6,IE7都生效
  +color:#555; +号对IE6--IE10都生效
  -color:#999; -号只对IE6生效
   _color:#888; _下划线只对IE6生效
  color:red\9;\9对 IE6/IE7/IE8/IE9/IE10都生效
  color:blue\0; \0对IE8/IE9/IE10都生效,是IE8/9/10的hack
  color:green\9\0; \9\0 只对IE9/IE10生效,是IE9/10的hack
   #color:pink; #号对IE6/IE7/IE8/IE9/IE10都生效
   
  */

看看怎么用的,来吧

  width: 300px\9;
  *width: 800px;
  _width: 300px;
   
  height: 120px;
  height: 60px\9;
  *height: 80px;
  _height: 100px;
  color: #FF6900;
  color: red\9;
  *color: deepskyblue;
  _color: #000;
  /*color:blue;*/
   
  background: #aaa;
  background: #ddd\9;
  *background: red;
  _background: #aaa;
  box-shadow: 0 0 5px #555;
  box-shadow: 0 0 5px #555\9;
  *box-shadow: 0 0 5px #555;
  _box-shadow: 0 0 5px #555;
  /*border: 1px solid #FF6900;*/
  /*border: 4px solid red\9;*/
  /**border: 8px solid deepskyblue;*/
  /*_border: 12px solid #000;*/
  text-align: center;
  line-height: 100px;

他也支持选择器的hack:

CSS选择器的Hack
   
  *html: 在选择器前面加 *html 表示该样式在IE6以及IE6以下版本浏览器生效
  :root: 在选择器前面加 :root 表示该样式在IE9及以上版本浏览器生效,对firefox和chrome也生效
  *+html: 在选择器前面加 *+html 表示该样式仅仅在IE7版本浏览器生效
  html>body: 在选择器前面加 html>body 表示该样式除IE6之外的所有浏览器都生效

例子:

*/
   
  *html .a {
  color:#fff;
  }
   
  :root .a {
  /*color: blue;*/
  }
  *+html .a{
  /*color:#ff6900;*/
  }
  html>body .a {
  color: green;
  }

Hack还支持html文本格式的兼容,意思是他可以找到你所匹配的IE版本,然而他并不是注释,第一次用它的话,哈哈哈,有可能你会觉得他是个注释,

同时也支持大于某一个版本,或者小于It某一个ie版本

<!--IE条件注释法(即HTML条件注释Hack)-->
  <!--[if IE]>
  <p>所有IE浏览器显示</p>
  <![endif]-->
   
  <!--[if IE 7]>
  <p>IE7浏览器显示,数字可以改 ,比如改成8,就是IE8浏览器显示</p>
  <![endif]-->
   
  <!--[if gte IE 6]>
  <p>IE6以上(包括)浏览器显示,数字可以改 ,比如改成7,就是IE7以上(包括)浏览器显示</p>
  <![endif]-->
   
  <!--[if ! IE 8]>
  <p>非IE8浏览器显示,数字可以改 ,比如改成9,就是非IE9浏览器显示</p>
  <![endif]-->
   
  <!--[if !IE]>
  <p>非IE浏览器显示</p>
  <![endif]-->

同理,在head里面,我们也可以写IE的兼容,例子来了

  <!--[if It IE 9]>
            <style>
      body{
        background-image: url(img/3.png);
        }
    </style>
    <![endif]-->
 
 
 
 
OK,关于hack的兼容应该差不多了,具体到某一个属性的兼容还需要继续查找,坑逼的IE

主要讲下hack的兼容用法,比较浅,哈哈的更多相关文章

  1. CentOS7下Firewall防火墙配置用法详解

    官方文档地址: https://access.redhat.com/documentation/en-US/Red_Hat_Enterprise_Linux/7/html/Security_Guide ...

  2. linux下find查找命令用法

    Linux下find命令在目录结构中搜索文件,并执行指定的操作.Linux下find命令提供了相当多的查找条件,功能很强大.由于find具有强大的功能,所以它的选项也很多,其中大部分选项都值得我们花时 ...

  3. IE6/IE7下margin-bottom失效兼容解决办法及双倍边距问题

    (从已经死了一次又一次终于挂掉的百度空间人工抢救出来的,发表日期 2014-04-08) 一.IE6/IE7下margin-bottom失效兼容解决办法 1.用padding-bottom代替:2.在 ...

  4. Asp.net服务器控件在IE10下的不兼容问题

    Asp.net服务器控件在IE10下的不兼容问题 时间:2013-05-16 09:07点击: 89 次 [大 中 小] 相信很多使用IE10的童鞋们已经发现了这个问题,以下是本人在IE10标准模式下 ...

  5. IE6-7下margin-bottom不兼容解决方法(非原创,视频中看到的)

    在IE低版本下有很多不兼容,现在将看到的   IE6-7下margin-bottom不兼容解决方法   演示一下,方便日后自己查阅. <!DOCTYPE html> <html la ...

  6. FCKEditor在IE10下的不兼容问题解决方法

    环境介绍:FCKEditor 版本 2.x.x 问题:IE10 下FCKEditor不兼容,显示不出来 关键词:不同于其他方法之处是第一个关键点,其他网友的正则表达式不对 解放方法:(可以直接< ...

  7. Scala中_(下划线)的常见用法

    Scala中_(下划线)的常见用法 地址:https://www.jianshu.com/p/0497583ec538

  8. windows和linux下目录分隔符兼容问题(换行回车兼容)

    windows和linux下目录分隔符兼容 DIRECTORY_SEPARATOR 换行回车兼容 PHP_EOF

  9. Bootstrap历练实例:导航内下拉菜单的用法

    <!DOCTYPE html><html><head><meta http-equiv="Content-Type" content=&q ...

随机推荐

  1. 201521123070 《JAVA程序设计》第14周学习总结

    1. 本章学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结多数据库相关内容. 2. 书面作业 Q1. MySQL数据库基本操作 建立数据库,将自己的姓名.学号作为一条记录插入.(截图,需出现 ...

  2. Modeling -> Mixamo auto rigging -> UE4 retargeting

    In general, there are 3 ways we can work with the Blender-UE4 pipeline:   1 Model character Export m ...

  3. log4j的基本使用和参数设定

    1.简介 apache的一个开放源代码项目. 精确控制日志的输出,包括输出的格式,输出的目的地,输出的过滤(不同级别日志的输出)等. 配置简单,不需要在代码中配置环境,支持两种配置文件格式,XML和J ...

  4. Redis集群介绍

    http://mt.sohu.com/20160601/n452401108.shtml

  5. 全方位解读"CPU load average"

    前一段时间,有同事因为“CPU负载到达5算不算高”的问题争论了一番,看似简单的一个问题表明了我们并没有真正理解服务器的CPU负载. 如果你的线上服务出现性能问题,那么检查机器的CPU负载情况是必不可少 ...

  6. SimpleRpc-网络事件响应Reactor设计模式

    前言 这篇文章主要介绍整个框架用到的最核的一个设计模式:反应器模式.这个设计模式可以在<面向对象的软件架构>中详细了解,没有这本书的小伙伴不要急,我通过咱们的SimpleRpc来告诉大家这 ...

  7. c语言中的内存浅析

    1.栈(stack):存局部变量.函数,调用函数时会开辟栈区,函数结束时就自动回收,遵循后进先出的原则,从高地址向低地址增长. 2.堆(heap):malloc.realloc.calloc等开辟的内 ...

  8. Java线程池带图详解

    线程池作为Java中一个重要的知识点,看了很多文章,在此以Java自带的线程池为例,记录分析一下.本文参考了Java并发编程:线程池的使用.Java线程池---addWorker方法解析.线程池.Th ...

  9. div内部实现图片旋转、放大、缩小、拖拽

    药药,切克闹,一人我编码累,累把那bug写成堆.秋高气爽空气干燥你一定dei多喝水,过完了这周我就要回去.趁还有几天.你尽情的来跟我怼~~~ 新的一年,很久没更博客了,眼看十一要来了,听说过了十一就等 ...

  10. ThinkPHP中,display和assign用法详解

    thinkphp 模板显示display和assign的用法 $this->assign('name',$value); //在 Action 类里面使用 assign 方法对模板变量赋值,无论 ...