Hack技术

1、IE条件注释法,微软官方推荐的hack方式。

只在IE下生效

<!--[if IE]>

<link rel="stylesheet" href="/ie-all.css" type="text/css" media="screen" />

<![endif]-->

只在IE6下生效

<!--[if IE 6]>

<link rel="stylesheet" href="/ie6.css" type="text/css" media="screen" />

<![endif]-->

只在IE6以上版本生效

<!--[if gt IE 6]>

<link rel="stylesheet" href="/gt-ie6.css" type="text/css" media="screen" />

<![endif]-->

只在IE7上不生效

<!--[if ! IE 7]>

<link rel="stylesheet" href="/not-ie7.css" type="text/css" media="screen" />

<![endif]-->

非IE浏览器生效

<!--[if !IE]><!-->

<link rel="stylesheet" href="/no-ie.css" type="text/css" media="screen" />

<!--<![endif]-->

2、常用的css hack代码

样式属性前缀法

.csshack{

background:blue;

background:blue\9; /*all ie*/

background:blue\0/; /*ie8-ie9*/

background/*\**/: blue\9; /* ie7-ie8*/

*background:blue;/* or #background: blue */ /*ie6-ie7*/

+background:blue; /*ie7*/

_background:blue; /*ie6*/

}

选择符前缀法

/* IE 7 */

*:first-child+html{}

/* IE 7 */

html > body #ie7  {  *display: block;  }

/* IE 6 */

* html #div{ }

/* IE 6 */

body #ie6  {  _display: block;  }

/*IE7及其更低版本*/

*:first-child+html{}*html{}

/*IE7,IE7以上和主流浏览器*/

html>body{}

/*适合主流浏览器(IE7排除在外,IE7以下的也不行)*/

html>/**/body{}

/* Firefox 1 - 2 */

body:empty #firefox12  {  display: block;  }

/* Firefox */

@-moz-document url-prefix(){ .sofish{padding:11px;}} /* all firefox */

/* Safari */

@media screen and (-webkit-min-device-pixel-ratio:0)  {

#safari { display: block; }  }

/* Opera */

@media all and (-webkit-min-device-pixel-ratio:10000), not all and (-webkit-min-device-pixel-ratio:0) { .sofish{padding:11px;} }

3、IE条件注释并不是只用于样式表文件,它还有其它的形式来进行Hack。

IE条件注释与style标签:

<!--[if IE 6]>

<style type="text/css"> /* css for IE 6 */ </style>

<![endif]-->

IE条件注释与script标签:

<!--[if IE 6]>

<script type="text/javascript"> alert("我是IE6"); </script>

<![endif]-->

IE条件注释与html标签:

<!--[if lt IE 7 ]> <html class="ie6"> <![endif]-->

4、IE CSS Media

/* IE6/7 only (via Keith Clarke) */

@media screen\9 { }

/* IE8 (via Keith Clarke) */

@media \0screen { }

/* IE6/7/8 (via Keith Clarke) */

@media \0screen\,screen\9 {}

/* IE8/9/10 */

@media screen\0 { }

@media screen and (min-width:0\0) {

body { background: yellow; }

}

Hack技术的更多相关文章

  1. HTML兼容问题——HACK技术

    有话先说:本文的目的主要是向大家描述一下我们在遇见IE8版本一下以及Firefox兼容的问题. 针对不同的浏览器写不同的CSS的过程,这就叫CSS hack,也叫写CSS hack,相信您会对一些比较 ...

  2. openwrt-智能路由器hack技术(2)---"网路信息监控和窃取"

    openwrt-智能路由器hack技术(2)---"网路信息监控和窃取" 1   导读 PS:之前写的一个文章,现在发现结构内容排版不是太好,导致阅读体验太差,影响传播和SEO,所 ...

  3. openwrt-智能路由器hack技术(1)---"DNS劫持"

    openwrt-智能路由器hack技术(1)---"DNS劫持" 1   导读 PS:之前写的一个文章,现在发现结构内容排版不是太好,导致阅读体验太差,影响传播和SEO,所以现在整 ...

  4. Web前端技术研究:Css hack技术---令人沮丧的技术

    我最近想好好整理下csshack技术,但是结果很沮丧,下面我将我最初写的笔记和大家分享下. 我在单位整理的研究笔记: 不同的浏览器对某些CSS代码解析会存在一定的差异,因此就会导致不同浏览器下给用户展 ...

  5. CSS Hack技术详解,支持IE 6-11、Chrome、FireFox、Safari、Opera 6-11、Chrome、FireFox、Safari、Opera6-11、Chrome、FireFox、Safari、Opera6-11、Chrome、FireFox、Safari、Opera

    转自: http://www.365mini.com/page/css-hack-ie-chrome-firefox-safari-opera.htm 当前网络时代,各种各样的网页向我们展示着丰富多彩 ...

  6. HTML的条件注释和hack技术

    在很多时候,前端的兼容性问题,都很让人头痛!幸运的是,微软从去年声明:从2016年1月12日起,微软将停止为IE8(包括IE8)提供技术支持和安全更新.整个前端圈子都沸腾起来,和今年七月份Adobe宣 ...

  7. HTML的条件注释及hack技术

    在很多时候,前端的兼容性问题,都很让人头痛!幸运的是,微软从去年声明:从2016年1月12日起,微软将停止为IE8(包括IE8)提供技术支持和安全更新.整个前端圈子都沸腾起来,和今年七月份Adobe宣 ...

  8. CSS Hack技术(一)

    这世间坑爹的东西不少,浏览器可以算做一件,尤其的IE浏览器.关于浏览器的吐槽已经有不少了,我也就不在这添油加醋了.不过吐槽终究只是泄一时之愤,解决问题才是关键,今天我们就来讲一讲浏览器(样式)兼容的技 ...

  9. CSS Hack技术介绍及常用的Hack技巧集锦

    一.什么是CSS Hack? 不同的浏览器对CSS的解析结果是不同的,因此会导致相同的CSS输出的页面效果不同,这就需要CSS Hack来解决浏览器局部的兼容性问题.而这个针对不同的浏览器写不同的CS ...

随机推荐

  1. 小甲鱼PE详解之IMAGE_NT_HEADERS结构定义即各个属性的作用(PE详解02)

    PE Header 是PE相关结构NT映像头(IMAGE_NT_HEADER)的简称,里边包含着许多PE装载器用到的重要字段.下边小甲鱼将为大家详细讲解哈~ (视频教程:http://fishc.co ...

  2. 《数据结构与算法分析》学习笔记(三)——链表ADT

    今天简单学习了下链表,待后续,会附上一些简单经典的题目的解析作为学习的巩固 首先要了解链表,链表其实就是由一个个结点构成的,然后每一个结点含有一个数据域和一个指针域,数据域用来存放数据,而指针域则用来 ...

  3. MIT 6.828 JOS学习笔记1. Lab 1 Part 1: PC Bootstrap

    Lab 1: Booting a PC Part 1: PC Bootstrap 介绍这一部分知识的目的就是让你能够更加熟悉x86汇编语言,以及PC启动的整个过程,而且也会首次学习使用QEMU软件来仿 ...

  4. Linux环境变量设置指南

    以配置java环境变量为例 目录 [隐藏]  1 修改/etc/profile文件 2 修改用户目录下的.bash_profile 3 修改.bashrc文件 4 直接在shell下设置 5 查看环境 ...

  5. 廖雪峰js教程笔记5 Arrow Function(箭头函数)

    为什么叫Arrow Function?因为它的定义用的就是一个箭头: x => x * x 上面的箭头函数相当于: function (x) { return x * x; } 箭头函数 阅读: ...

  6. 《DSP using MATLAB》示例Example5.3

  7. Codeforce 546D

    Soldier and Number Game Time Limit:3000MS     Memory Limit:262144KB     64bit IO Format:%I64d & ...

  8. DP(记忆化搜索) + AC自动机 LA 4126 Password Suspects

    题目传送门 题意:训练指南P250 分析:DFS记忆化搜索,范围或者说是图是已知的字串构成的自动机图,那么用 | (1 << i)表示包含第i个字串,如果长度为len,且st == (1 ...

  9. three.js正交投影照相机

    照相机又分为正交投影照相机与透视投影照相机 举个简单的例子来说明正交投影与透视投影照相机的区别.使用透视投影照相机获得的结果是类似人眼在真实世界中看到的有"近大远小"的效果(如下图 ...

  10. Recurrent Neural Network(循环神经网络)

    Reference:   Alex Graves的[Supervised Sequence Labelling with RecurrentNeural Networks] Alex是RNN最著名变种 ...