div+css教程:CSS兼容性(IE和Firefox)技巧大全

DIV+CSS 21NN 3个月前 (05-24) 12次浏览 已收录 0个评论 扫描二维码

CSS 对浏览器的兼容性有时让人很头疼,或许当你了解当中的技巧跟原理,就会觉得也不是难事,从网上收集了 IE7,6 与 Fireofx 的兼容性处理
技巧并整理了一下。对于 web2.0 的过度,请尽量用 xhtml 格式写代码,而且 DOCTYPE 影响 CSS 处理,作为 W3C 的标准,一定要加
DOCTYPE 声明。
CSS 技巧
1.div 的垂直居中问题
vertical-align:middle; 将行距增加到和整个 DIV 一样高 line-height:200px; 然后插入文字,就垂直居中了。缺点是要控制内容不要换行
2. margin 加倍的问题
设置为 float 的 div 在 ie 下设置的 margin 会加倍。这是一个 ie6 都存在的 bug。解决方案是在这个 div 里面加上 display:inline;
例如:

相应的 css 为
#imfloat{
float:left;
margin:5px;/*IE 下理解为 10px*/
display:inline;/*IE 下再理解为 5px*/}
3.浮动 ie 产生的双倍距离
#box{ float:left; width:100px; margin:0 0 0 100px; //这种情况之下 IE 会产生 200px 的距离 display:inline; //使浮动忽略}
这里细说一下 block 与 inline 两个元素:block 元素的特点是,总是在新行上开始,高度,宽度,行高,边距都可以控制(块元素);Inline 元素的特点是,和其他元素在同一行上,不可控制(内嵌元素);
#box{ display:block; //可以为内嵌元素模拟为块元素 display:inline; //实现同一行排列的效果 diplay:table;
4 .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;}
5.页面的最小宽度
min-width 是个非常方便的 CSS 命令,它可以指定元素最小也不能小于某个宽度,这样就能保证排版一直正确。但 IE 不认得这个,而它实际上把
width 当做最小宽度来使。为了让这一命令在 IE 上也能用,可以把一个<div> 放到 <body>
标签下,然后为 div 指定一个类,然后 CSS 这样设计:
#container{ min-width: 600px; width:expression(document.body.clientWidth < 600? “600px”: “auto” );}
第一个 min-width 是正常的;但第 2 行的 width 使用了 Javascript,这只有 IE 才认得,这也会让你的 HTML 文档不太正规。它实际上通过 Javascript 的判断来实现最小宽度。

6.DIV 浮动 IE 文本产生 3 象素的 bug
左边对象浮动,右边采用外补丁的左边距来定位,右边对象内的文本会离左边有 3px 的间距.
#box{ float:left; width:800px;}
#left{ float:left; width:50%;}
#right{ width:50%;}
*html #left{ margin-right:-3px; //这句是关键}

</div>

</div>

7.IE 捉迷藏的问题
当 div 应用复杂的时候每个栏中又有一些链接,DIV 等这个时候容易发生捉迷藏的问题。
有些内容显示不出来,当鼠标选择这个区域是发现内容确实在页面。 解决办法:对#layout 使用 line-height 属性 或者给#layout 使用固定高和宽。页面结构尽量简单。
8.float 的 div 闭合;清除浮动;自适应高度
①例如:<#div id=”floatA” ><#div id=”floatB” ><#div id=”NOTfloatC”
>这里的 NOTfloatC 并不希望继续平移,而是希望往下排。(其中 floatA、floatB 的属性已经设置为 float:left;)
这段代码在 IE 中毫无问题,问题出在 FF。原因是 NOTfloatC 并非 float 标签,必须将 float 标签闭合。

<!–
html {
scrollbar-face-color:#f6f6f6;
scrollbar-highlight-color:#fff;
scrollbar-shadow-color:#eeeeee;
scrollbar-3dlight-color:#eeeeee;
scrollbar-arrow-color:#000;
scrollbar-track-color:#fff;
scrollbar-darkshadow-color:#fff;
}
–>
</style>
15.为什么无法定义 1px 左右高度的容器
IE6 下这个问题是因为默认的行高造成的,解决的技巧也有很多,例如:overflow:hidden   zoom:0.08   line-height:1px
16.怎么样才能让层显示在 FLASH 之上呢
解决的办法是给 FLASH 设置透明

17.怎样使一个层垂直居中于浏览器中
这里我们使用百分比绝对定位,与外补丁负值的技巧,负值的大小为其自身宽度高度除以二

<!–
div {
position:absolute;
top:50%;
lef:50%;
margin:-100px 0 0 -100px;
width:200px;
height:200px;
border:1px solid red;
}
–>

FF 与 IE

1. Div 居中问题
div 设置 margin-left, margin-right 为 auto 时已经居中,IE 不行,IE 需要设定 body 居中,首先在父级元素定义 text-algin: center;这个的意思就是在父级元素内的内容居中。
2.链接(a 标签)的边框与背景
a 链接加边框和背景色,需设置 display: block, 同时设置 float: left 保证不换行。参照 menubar, 给 a 和
menubar 设置高度是为了避免底边显示错位, 若不设 height, 可以在 menubar 中插入一个空格。
3.超链接访问过后 hover 样式就不出现的问题
被点击访问过的超链接样式不在具有 hover 和 active 了,很多人应该都遇到过这个问题,解决技巧是改变 CSS 属性的排列顺序: L-V-H-A
Code:

<!–
a:link {}
a:visited {}
a:hover {}
a:active {}
–>

4. 游标手指 cursor
cursor: pointer 可以同时在 IE FF 中显示游标手指状, hand 仅 IE 可以
5.UL 的 padding 与 margin
ul 标签在 FF 中默认是有 padding 值的,而在 IE 中只有 margin 默认有值,所以先定义 ul{margin:0;padding:0;}就能解决大部分问题
6. FORM 标签
这个标签在 IE 中,将会自动 margin 一些边距,而在 FF 中 margin 则是 0,因此,如果想显示一致,所以最好在 css 中指定 margin 和
padding,针对上面两个问题,我的 css 中一般首先都使用这样的样式 ul,form{margin:0;padding:0;}给定义死了,所以后
面就不会为这个头疼了.
7. BOX 模型解释不一致问题
在 FF 和 IE 中的 BOX 模型解释不一致导致相差 2px 解决技巧:div{margin:30px!important;margin:28px;}
注意这两个 margin 的顺序一定不能写反, important 这个属性 IE 不能识别,但别的浏览器可以识别。所以在 IE 下其实解释成这样:
div{maring:30px;margin:28px}重复定义的话按照最后一个来执行,所以不可以只写 margin:xx
px!important;#box{ width:600px; //for ie6.0- width:500px; //for
ff+ie6.0}
#box{ width:600px!important //for ff width:600px; //for ff+ie6.0 width /**/:500px; //for ie6.0-}
8.属性选择器(这个不能算是兼容,是隐藏 css 的一个 bug)
p[id]{}div[id]{}
这个对于 IE6.0 和 IE6.0 以下的版本都隐藏,FF 和 OPera 作用.属性选择器和子选择器还是有区别的,子选择器的范围从形式来说缩小了,属性选择器的范围比较大,如 p[id]中,所有 p 标签中有 id 的都是同样式的.

9.最狠的手段 – !important
如果实在没有办法解决一些细节问题,可以用这个技巧.FF 对于”!important”会自动优先解析,然而 IE 则会忽略


乐趣公园 , 版权所有丨如未注明 , 均为原创丨本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:div+css 教程:CSS 兼容性(IE 和 Firefox)技巧大全
喜欢 (0)
[1353713598@qq.com]
分享 (0)
关于作者:
发表我的评论
取消评论
表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址