元素CSShack:针对IE6IE7IE8IE9firefox显示不同效果

csshack  时间:2021-04-22  阅读:()

CSS hack针对IE6 IE7 IE8 IE9 firefox显示不同效果

区别不同浏览器的CSS hack写法

区别IE6与其它浏览器background:orange;_background:blue;

区别IE6与IE7background:green! important;background:blue;

区别IE6、 IE7与FFbackground:orange; *background:green;

区别FF IE7 IE6background:orange;*background:green! important;*background:blue;

区别IE与非IE浏览器background:orange;background:green\9;所有IE浏览器都识别(IE6、 IE7、

IE8、 IE9)

注 IE6/7能识别*;标准浏览器(如FF)不能识别*background-color:orange\0; /*识别ie 8/9*/background-color:orange\9\0; /*识别ie 9*/

IE6能识别*但不能识别! important,

IE7能识别*也能识别! important;

FF不能识别*但能识别! important;

IE6 IE7 FF

------------------------------------------------------

另外再补充一个下划线"_",

IE6支持下划线 IE7和firefox均不支持下划线。

IE6 IE7 FF * √ √ × × √ √ _ √ × ×

! important

于是大家还可以这样来区分IE6 IE7 firefox

: background:orange;*background:green;_background:blue;

注不管是什么方法书写的顺序都是firefox的写在前面 IE7的写在中间 IE6的写在最后面。

一、 CSS HACK

以下两种方法几乎能解决现今所有HAC K.

1 , ! important

随着IE7对! important的支持, ! important方法现在只针对IE6的HACK.(注意写法.记得该声明位置需要提前.)

<stylegt;

#wrapper

{width: 100px! important; /* IE7+FF*/width:80px; /* IE6*/

}

</stylegt;

2, IE6/IE77对FireFox

*+html与*html是IE特有的标签, firefox暂不支持.而*+html又为IE7特有标签.<style>

#wrapper

{

#wrapper {width: 120px; } /*FireFox*/

*html#wrapper {width:80px;} /* ie6 fixed*/

*+html#wrapper {width:60px;} /* ie7 fixed,注意顺序*/

}

</style>

注意:

*+html对IE7的HACK必须保证HTML顶部有如下声明

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN""http://www.w3.org/TR/html4/loose.dtd">

二、万能float闭合(非常重要!)

关于clearfloat的原理可参见[HowTo Clear Floats Without Structural Markup]

将以下代码加入Global CSS中,给需要闭合的div加上><style>

/*Clear Fix*/

.clearfix:after

{content:".";display:block;height:0;clear:both;visibi l ity:hidden;

}

.clearfix

{display: inl ine-block;

}

/*Hide from IE Mac*/

.clearfix{display:block;}

/*End hide from IE Mac*/

/*end of clearfix*/

</style>

关于闭合浮动元素clearing float的方法现在已经很多了个人认为简单实用的方法就是使用:after伪类动态的嵌入一个用于清除浮动的元素可惜代码量太大了看上去不够简洁。现在看到有个方法超级简单。 介绍一下这个方法。 原文在http://annevankesteren.nl/2005/03/clearing-floats

这一方面的原理是外围元素之所以不能很好的延伸 问题出在了overflow上 因为overflow不可见见W3C的解释。现在只要将给外围元素添加一个“overflow:auto” 就可以解决问题结果是除了IE真的可以解决。下来就要解决ID的问题了再加上“_height:1%” 这个问题就完全解决了。

下面的例子作为比较

1 、没有闭合浮动元素 2、非IE下闭合浮动元素 3、完全闭合元素。相关代码如下XHT ML代码

Example Source Code[www.52css.com]

<div id="wrap">

<div class="column_left">

<h1>Float left</h1>

</div>

<div class="column_right">

<h1>Float right</h1>

</div>

</div>

CSS样式

Example Source Code[www.52css.com]

#wrap{border:6px#ccc sol id;overflow:auto;_height:1%;}

.column_left{ float: left;width:20%;padding:10px;}

.column_right{ float:right;width:75%; padding:10px;border-left:6px#eee sol id;}

三、其他兼容技巧(再次啰嗦)

1 ,FF下给div设置padding后会导致width和height增加,但IE不会.(可用! important解决)

2,居中问题.

1).垂直居中.将 l ine-height设置为 当前div相同的高度,再通过vertical-al ign:middle.(注意内容不要换行.)

2).水平居中.margin:0 auto;(当然不是万能)

3,若需给a标签内内容加上样式,需要设置display:block;(常见于导航标签)

4, FF和IE对BOX理解的差异导致相差2px的还有设为float的div在ie下margin加倍等问题.

5, ul标签在FF下面默认有l ist-style和padding .最好事先声明,以避免不必要的麻烦.(常见于导航标签和内容列表)

6,作为外部wrapper的div不要定死高度,最好还加上overflow: hidden.以达到高度自适应.

7,关于手形光标.cursor:pointer.而hand只适用于IE.

1针对firefox ie6 ie7的css样式

现在大部分都是用! important来hack对于ie6和firefox测试可以正常显示

但是ie7对! important可以正确解释会导致页面没按要求显示找到一个针

对IE7不错的hack方式就是使用“*+html” 现在用IE7浏览一下应该没有问题了。现在写一个CSS可以这样

#1 {color:#333; } /*Moz*/

*html#1 {color:#666; } /* IE6*/

*+html#1 {color:#999; } /* IE7*/

那么在firefox下字体颜色显示为#333 IE6下字体颜色显示为#666 IE7下字体颜色显示为#999。

2 css布局中的居中问题

主要的样式定义如下body{TEXT-AL IG N:center;}

#center {MARGI N-RIG HT:auto;MARGI N-LEFT:auto; }

说明

首先在父级元素定义TEXT-ALIG N:center;这个的意思就是在父级元素内的内容居中对于IE这样设定就已经可以了。

但在mozi l la中不能居中。解决办法就是在子元素定义时候设定时再加上“MARGIN-RIGHT:auto;MARGI N-LEFT:auto; ”

需要说明的是如果你想用这个方法使整个页面要居中建议不要套在一个DIV里你可以依次拆出多个div

只要在每个拆出的div里定义MARG I N-RIGHT:auto;MARG I N-LEFT:auto;就可以了。3盒模型不同解释.

#box{width:600px; //for ie6.0-w\idth:500px; //forff+ie6.0}

#box{width:600px! important //forff width:600px; //for ff+ie6.0 width/**/:500px; //for ie6.0-}4浮动ie产生的双倍距离

#box{ float: left;width:100px;margin:000 100px; //这种情况之下IE会产生200px的距离display: inl ine; //使浮动忽略}

这里细说一下block, inl ine两个元素,Block元素的特点是:总是在新行上开始,高度,宽度,行高,边距都可以控制(块元素); Inl ine元素的特点是:和其他元素在同一行上, . . .不可控制(内嵌元素);#box{ display:block; //可以为内嵌元素模拟为块元素display: inl ine; //实现同一行排列的的效果diplay:table;

5 IE与宽度和高度的问题

IE不认得min-这个定义但实际上它把正常的width和height当作有min的情况来使。这样问题就大了如果只用宽度和高度

正常的浏览器里这两个值就不会变如果只用min-width和min-height的话 IE下面根本等于没有设置宽度和高度。

比如要设置背景图片这个宽度是比较重要的。要解决这个问题可以这样

#box{width: 80px; height: 35px;}html>body#box{width: auto; height: auto;min-width:80px;min-height:35px;}

6页面的最小宽度min-width是个非常方便的CSS命令它可以指定元素最小也不能小于某个宽度这样就能保证排版一直正确。但IE不认得这个

而它实际上把width当做最小宽度来使。为了让这一命令在IE上也能用可以把一个<div>放到<body>标签下然后为div指定一个类

然后CSS这样设计

#container{ min-width: 600px; width:expression(document.body.cl ientWidth < 600?"600px": "auto" );}

第一个min-width是正常的但第2行的width使用了Javascript这只有IE才认得这也会让你的HTML文档不太正规。它实际上通过Javascript的判断来实现最小宽度。

7清除浮动

.hackbox{display:table; //将对象作为块元素级的表格显示}或者.hackbox{clear:both;}或者加入:after 伪对象 ,设置在对象后发生的内容通常和content配合使用 IE不支持此伪对象非Ie浏览器支持

所以并不影响到IE/WIN浏览器。这种的最麻烦的. . . . . .#box:after{content: ".";display:block;height:0;clear:both;visibi l ity: hidden;}

8 DIV浮动IE文本产生3象素的bug

左边对象浮动右边采用外补丁的左边距来定位右边对象内的文本会离左边有3px的间距.

#box{ float: left; width:800px;}#left{ float: left; width:50%;}#right{ width:50%;}*html#left{margin-right:-3px; //这句是关键}

HTML代码<div id="box"><div id="left"></div><div id="right"></div></div>

9属性选择器(这个不能算是兼容,是隐藏css的一个bug)p[id]{}div[id]{}

这个对于IE6.0和IE6.0以下的版本都隐藏,FF和OPera作用

属性选择器和子选择器还是有区别的,子选择器的范围从形式来说缩小了,属性选择器的范围比较大,如p[id]中,所有p标签中有id的都是同样式的.

10 IE捉迷藏的问题

当div应用复杂的时候每个栏中又有一些链接 DIV等这个时候容易发生捉迷藏的问题。有些内容显示不出来 当鼠标选择这个区域是发现内容确实在页面。

解决办法对#layout使用l ine-height属性或者给#layout使用固定高和宽。页面结构尽量简单。

11高度不适应

高度不适应是当内层对象的高度发生变化时外层高度不能自动进行调节特别是当内层对象使用margin或paddign时。

例

<div id="box">

p对象中的内容

</div>

CSS #box{background-color:#eee; }

#box p{margin-top:20px;margin-bottom:20px; text-al ign:center; }

解决方法在P对象上下各加2个空的div对象CSS代码 .1{height:0px;overflow:hidden;}或者为D IV加上border属性。

更多好文章请点击 http://www.jq-schoo l.com

LOCVPS:VPS主机全场8折,德国/荷兰/美国KVM终身7折

LOCVPS发来了针对元旦新年的促销活动,除了全场VPS主机8折优惠外,针对德国/荷兰KVM #1/美国KVM#2 VPS提供终身7折优惠码(限量50名,先到先得)。LOCVPS是一家成立于2012年的国人VPS服务商,提供中国香港、韩国、美国、日本、新加坡、德国、荷兰、俄罗斯等地区VPS服务器,基于KVM或XEN架构(推荐优先选择KVM),均选择直连或者优化线路,国内延迟低,适合建站或远程办公使...

王小玉网-美国洛杉矶2核4G 20元/月,香港日本CN2 2核2G/119元/季,美国300G高防/80元/月!

 活动方案:美国洛杉矶 E5 2696V2 2核4G20M带宽100G流量20元/月美国洛杉矶E5 2696V2 2核4G100M带宽1000G流量99元/季香港CN2 E5 2660V2 2核2G30M CN2500G流量119元/季日本CN2E5 2660 2核2G30M CN2 500G流量119元/季美国300G高防 真实防御E5 2696V2 2核2G30M...

JUSTG(5.99美元/月)最新5折优惠,KVM虚拟虚拟512Mkvm路线

Justg是一家俄罗斯VPS云服务器提供商,主要提供南非地区的VPS服务器产品,CN2高质量线路网络,100Mbps带宽,自带一个IPv4和8个IPv6,线路质量还不错,主要是用户较少,带宽使用率不高,比较空闲,不拥挤,比较适合面向非洲、欧美的用户业务需求,也适合追求速度快又需要冷门的朋友。justg的俄罗斯VPS云服务器位于莫斯科机房,到美国和中国速度都非常不错,到欧洲的平均延迟时间为40毫秒,...

csshack为你推荐
档案管理系统常见问题及解决办法centrescss支持ipad支持ipadipad上网为什么我的ipad 显示无法连接到网络win7关闭135端口win7下怎么关135和8909端口chromeframe谷歌浏览器(Chrome) 与(Chromium) 有什么区别?哪个更快?迅雷雷鸟啊啊,想下载《看门狗》可13GB的大小,我每秒才450KB,我该怎么样才能大幅度地免费提高电脑下载routeaddroute add 添加路由的命令,内网和外网如何同时上bitchina2015年igem国内大学参加结果
免费申请网站域名 个人域名备案流程 电信测速器 绍兴高防 支付宝扫码领红包 Updog 中国linux photobucket 国外免费网盘 亿库 windowssever2008 asp介绍 美国达拉斯 游戏服务器 neicun 电脑主机声音大 kosskeb4 sockscap怎么用 qq空间技术网 服务器监测软件 更多