博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
针对IE6\7\8\9\10浏览器的CSS hack大全详解
阅读量:6992 次
发布时间:2019-06-27

本文共 1910 字,大约阅读时间需要 6 分钟。

hot3.png

目前IE内核浏览器仍然是国内主流浏览器,占据着PC浏览器的大部分市场份额,版本从IE6到IE10,所有前段工作者都必须面对和解决多个IE浏览器对代码的兼容性问题。在很多情况下,我们需要专门针对IE写css样式,即针对IE的css hack,下面将详细介绍这些内容:

1、常见的特殊符号的应用:

IE6:

_selector{property:value;}

selector{property:value;property:value !important;} //IE6 不支持同一选择符中的 !important

IE7:

+selector{property:value;}

IE8:

selector{property:value\0;}

IE6 & IE7:

*selector{property:value;}

IE6 & IE7 & IE8:

selector{property:value\9;}

总结起来,如下:

其中,S表示Standards Mode即标准模式,Q表示Quirks Mode,即兼容模式。

(了解更多、?)

hack

示例

IE6(S)

IE6(Q)

IE7(S)

IE7(Q)

IE8(S)

IE8(Q)

*

*color

Yes

Yes

Yes

Yes

No

Yes

+

+color

Yes

Yes

Yes

Yes

No

Yes

-

-color

Yes

Yes

No

No

No

No

_

_color

Yes

Yes

No

Yes

No

Yes

#

#color

Yes

Yes

Yes

Yes

No

Yes

\0

color\0

No

No

No

No

Yes

No

\9

color\9

Yes

Yes

Yes

Yes

Yes

Yes

!important

color:blue !important;

color:green;

No

No

Yes

No

Yes

No

2、条件注释语句(<!--[if IE]> <![endif]-->)

<!--[if IE]> 所有的IE可识别 <![endif]-->

<!--[if !IE]><!--> 除IE外都可识别 <!--<![endif]-->
<!--[if IE 6]> 仅IE6可识别 <![endif]-->
<!--[if lt IE 6]> IE6以下版本可识别 <![endif]-->
<!--[if gte IE 6]> IE6以及IE6以上版本可识别 <![endif]-->
<!--[if IE 7]> 仅IE7可识别 <![endif]-->
<!--[if lt IE 7]> IE7以下版本可识别 <![endif]-->
<!--[if gte IE 7]> IE7以及IE7以上版本可识别 <![endif]-->
<!--[if IE 8]> 仅IE8可识别 <![endif]-->
<!--[if IE 9]> 仅IE9可识别 <![endif]-->

lt 表示less than 当前条件版本以下的版本,不包含当前版本。

gte 表示greeter than or equal 当前版本以上版本,并包含当前版本。

lte 表示less than or equal 当前版本以下版本,并包含当前版本。

3、meta声明

由于IE8 可能会将页面按照 IE7 模式进行渲染,针对 多版本IE的现状,通常会采用设置 X-UA-Compatible HTTP 头的方式将页面在IE中采用统一的渲染模式。

//标准 IE7 模式
//兼容 IE7 模式
//标准 IE 模式

4、其他(/*\**/注释法)

网上也流传着这样一种ie hack方法

.color1{ color:#F00; color/*\**/:#00F /*\**/}/*IE6,IE7,IE8,FF,OP,SA识别*/

.color2{ color:#F00; color /*\**/:#00F /*\9**/}/*IE7,IE8,FF,OP,SA识别*/
.color3{ color:#F00; color/*\**/:#00F \9}/*IE6,IE7,IE8识别*/
.color4{ color:#F00; color /*\**/:#00F\9}/*IE7,IE8识别*//*“color”和“/*\**/”之间有个空格*/

转自请注明文章转自五月兰博客:

转载于:https://my.oschina.net/wuyuelanbeta/blog/86928

你可能感兴趣的文章
Python发送各类邮件的主要方法
查看>>
nginx同一端口监听多个域名和同时监听http,https
查看>>
关于win7系统的设置文件共享与远程连接的步骤整理
查看>>
每天一个linux命令(11):nl命令
查看>>
Apache2.2+tomcat负载均衡session共享配置说明手册1.1版
查看>>
PHP 5.3.0以上推荐使用mysqlnd驱动
查看>>
vue.js中使用d3.js画家谱关系图
查看>>
python实现跨文件全局变量的方法
查看>>
grails的那个编码,老是忘记,记这里。。。。。
查看>>
禁用arcgis security service
查看>>
火狐ssl_error_weak_server_ephemeral_dh_key解决办法
查看>>
Exchange DAG error
查看>>
Windows7安全性的五件应该知道的事
查看>>
ON CONFLICT子句
查看>>
Delphi对保存数据库连接信息的Ini文件的操作类
查看>>
大数相加
查看>>
简单的nginx服务脚本
查看>>
现实社会做点事情真难~难~难~难
查看>>
Docker 完全指南
查看>>
自己建OpenERP群
查看>>