常见的IE6兼容以及css兼容

迈着小短腿的YY

常见的IE6兼容以及css兼容

IE6虽然随着XP系统退出市场在国外基本基本消失,但是在国内依然占据很大的市场份额。政务网站、页游官网等依然要考虑到IE6用户的体验。如果你的网站使用CSS3等“新技术”时,就必须果断放弃IE6的兼容。

  • 浏览器添加默认样式

问题:

有些浏览器会给浏览器添加默认样式,而且不同浏览器添加的样式不同,导致布局在不同浏览器发生不同的错乱。

解决:

清楚默认样式,保证不同浏览器样式统一。(百度中有很多不错的清除样式模板)以下是我自己常用的清除样式文件:

 1 body, h1, h2, h3, h4, h5, h6, hr, p, blockquote,dl, dt, dd, ul, ol, li,pre,fieldset, button, input, textarea,th, td { margin: 0;padding: 0;}/* 设置默认字体 */
 2 body,button, input, select, textarea { /* for ie */ font: 14px/1.5 arial,"Microsoft Yahei","Hiragino Sans GB",sans-serif; /* 用 ascii 字符表示,使得在任何编码下都无问题 */ }
 3 h1 { font-size: 18px; /* 18px / 12px = 1.5 */ }
 4 h2 { font-size: 16px; }
 5 h3 { font-size: 14px; }
 6 h4, h5, h6 { font-size: 100% }
 7 img { height: auto;vertical-align: middle;border: 0 none;}
 8 address, cite, dfn, em, var { font-style: normal; } /* 将斜体扶正 */
 9 code, kbd, pre, samp, tt { font-family: "Courier New", Courier, monospace; } /* 统一等宽字体 */
10 small { font-size: 12px; } /* 小于 12px 的中文很难阅读,让 small 正常化 */
11 ul, ol { list-style: none; }
12 /* 重置文本格式元素 */
13 a { text-decoration: none; }
14 abbr[title], acronym[title] { /* 注:1.ie6 不支持 abbr; 2.这里用了属性选择符,ie6 下无效果 */ border-bottom: 1px dotted;cursor: help;}
15 q:before, q:after { content: ‘‘; }
16 /* 重置表单元素 */
17 legend { color: #000; } /* for ie6 */
18 fieldset, img { border: none; } /* img 搭车:让链接里的 img 无边框 */
19 /* 注:optgroup 无法扶正 */
20 button, input, select, textarea { font-size: 100%; margin: 0;vertical-align: baseline; /* 使得表单元素在 ie 下能继承字体大小 */ }
21 table {border-collapse: collapse;border-spacing: 0;}
22 hr {border: none;height: 1px;}
23 /* 让非ie浏览器默认也显示垂直滚动条,防止因滚动条引起的闪烁 */
24 html { overflow-y: scroll;}
25 body{font: 14px/1.5 arial,"Microsoft Yahei","Hiragino Sans GB",sans-serif;color: #8C8C8C;}

  • img标签底部间隙

问题:

div中包含一张图片,底部可能有2px、4px或更多的间隙,不同的font-size会影响间隙的大小。

解决:

  1. 将图片的垂直对齐方式vertical-align值设为top或bootm
  2. 将图片转化为块元素,display:block;
  3. 将包含图片的父容器字体大小设为0,font-size:0;
  • img在IE有蓝色边框

问题:

img标签在IE6-IE10加了超链接(a标签)后蓝色边框

解决:

img{border:0;}

  • margin上下边距合并

问题:

同时给上下容器添加上下边距会出现边距合并问题(合并最大的值)

解决:

不要同时给两个上下边距,只给一个就好。

  • margin-top没有加到指定元素上

问题:

在容器中给子元素一个margin-top没有想要的效果。

解决:

  1. 给父元素一个透明的像素边框 border:1px solid rgba(0,0,0,0);
  2. 通过给父元素一个padding-top来模拟margin-top。
  • IE6双倍边距

问题:

给浮动元素加margin-left时IE6会出现双倍边距。

解决:

给浮动元素display:inline;

  • 子元素浮动时父元素高度为0

问题:

父元素高度不确定,子元素浮动时,父元素高度变为0。浮动子元素层级高于父元素导致撑不开父元素。

解决:

  1. 父容器添加overflow:hidden;
  2. 在子元素后添加一个空div清除浮动 <div style="height:0;overflow:hidden;clear:both;"></div>
  • IE6不支持固定定位

问题:

IE6不支持position:fixed;

解决:

1 选择器{width: 200px;height: 200px;background: red;position: fixed;bottom: 50px;right: 50px;*position: absolute;*top: expression(eval(document.documentElement.scrollTop+200));}
2 *html{background-image: url("blank:about");background-attachment: absolute;}
  • IE6不支持png透明

问题:

IE6下png透明度不支持

解决:

background-image:url(123.png); _background:none; _filter: progid:DXImageTransform.Microsoft.AlphaImageLoader(src=‘123.png‘);

滤镜中的图片路径应该是绝对路径。

  • <!DOCTYPE HTML>文档类型的声明

问题:

IE6浏览器,当我们没有书写这个文档声明的时候,会触发IE6浏览器的怪异解析现象。

解决:

书写文档声明。

  • IE6默认行高

问题:

IE6、IE7、遨游浏览器;设置的文字高度超出盒模型内容区域设置的高度时会影响布局。

解决:

给超出高度的标签设置overflow:hidden;或者将文字的行高line-height设置为小于块的高度。

  • IE6 3px的bug

问题:

IE6浮动元素与非浮动元素处于一行有默认的3px间距。

解决:

设置所有元素浮动。

  • IE6只支持a链接的hover

问题:

IE6只支持a的hover不支持其他元素的hover。

解决:

使用JS模拟a:hover或者合理嵌套a链接。

  • IE6透明rgba与opacity

问题:

IE6不支持此两种透明的设置方法。

解决:

使用IE6当中的滤镜filter替代掉,如:opacity:0.6;_filter:alpha(opacity=60)。

  • IE6不支持min/max-height

问题:

IE6不支持min/max-height。

解决:

为IE6单独设置hack,即_height:最小高度值;_width:最小宽度值;

  • IE6li的间距问题

问题:

IIE6浏览器 li标签设置宽高,且li里面的元素发生了浮动。

解决:

  1. li不设置宽高。
  2. li内部元素不浮动。
  • a链接点击时有蓝色边框

问题:

a链接点击时有蓝色边框。

解决:

a:focus { outline: none 0; }
  • li在IE6自适应消失

问题:

如果li中有块元素在IE6下虽然浮动,默认宽度是100%而不是自适应。

解决:

  1. li设置固定宽度
  2. display:inline_block;
时间: 2024-10-13 02:32:04

常见的IE6兼容以及css兼容的相关文章

Javascript兼容和CSS兼容总结

javascript部分 1. document.form.item 问题问题:代码中存在 document.formName.item(“itemName”) 这样的语句,不能在FF下运行解决方法:改用 document.formName.elements["elementName"] 2. 集合类对象问题问题:代码中许多集合类对象取用时使用(),IE能接受,FF不能解决方法:改用 [] 作为下标运算,例:document.getElementsByName(“inputName”)

DIV+CSS IE6/IE7/IE8/FF兼容问题汇总

1.IE8下兼容问题,这个最好处理,转化成ie7兼容就可以.在头部加如下一段代码,然后只要在IE7下兼容了,IE8下面也就兼容了 <meta http-equiv="x-ua-compatible" content="ie=7" /> 2.flaot浮动造成IE6下面双倍边距问题,这个最常见,也最好处理,!important解决,比如 margin-left:10px !important;; margin-left:5px; +height:120px

div+css 兼容ie6 ie7 ie8 ie9和FireFox Chrome等浏览器方法(非原创)

div+css 兼容ie6 ie7 ie8 ie9和FireFox Chrome等浏览器方法 1.DOCTYPE 影响 CSS 处理 2.FF: div 设置 margin-left, margin-right 为 auto 时已经居中, IE 不行 3.FF: body 设置 text-align 时, div 需要设置 margin: auto(主要是 margin-left,margin-right) 方可居中 4.FF: 设置 padding 后, div 会增加 height 和 wi

ie6,ie7,ie8 css bug兼容解决记录

ie6,ie7,ie8 css bug兼容解决记录 转载自:ie6,ie7,ie8 css bug兼容解决记录 - 前端开发 断断续续的在开发过程中收集了好多的bug以及其解决的办法,都在这个文章里面记录下来了!希望以后解决类似问题的时候能够快速解决 ,也希望大家能在留言里面跟进自己发现的ie6 7 8bug和解决办法! 1:li边距“无故”增加 任何事情都是有原因的,li边距也不例外. 先描述一下具体状况:有些时候li边距会突然增 加很多,值也不固定(只在IE6/IE7有这种现象),让人摸不着

{转}div+css 兼容ie6 ie7 ie8 ie9和FireFox Chrome等浏览器方法

div+css 兼容ie6 ie7 ie8 ie9和FireFox Chrome等浏览器方法 1.DOCTYPE 影响 CSS 处理 2.FF: div 设置 margin-left, margin-right 为 auto 时已经居中, IE 不行 3.FF: body 设置 text-align 时, div 需要设置 margin: auto(主要是 margin-left,margin-right) 方可居中 4.FF: 设置 padding 后, div 会增加 height 和 wi

DIV+CSS IE6/IE7/IE8/FF兼容问题大全

1. [代码][CSS]代码 1, FF下给 div 设置 padding 后会导致 width 和 height 增加, 但IE不会.(可用!important解决) 2, 居中问题. 1).垂直居中.将 line-height 设置为 当前 div 相同的高度, 再通过 vetical-align: middle.( 注意内容不要换行.) 2).水平居中. margin: 0 auto;(当然不是万能) 3, 若需给 a 标签内内容加上 样式, 需要设置 display: block;(常见

CSS兼容IE6,IE7,FF的技巧(COPY来的,还没看)

一.CSS HACK 以下两种方法几乎能解决现今所有HACK.翻阅很多资料,已测试可以使用. 1, !important 随着IE7对!important的支持, !important 方法现在只针对IE6的HACK.(注意写法.记得该声明位置需要提前.) PLAIN TEXT CSS: #wrapper { width: 100px!important; /* IE7+FF */ width: 80px; /* IE6 */ } 2, IE6/IE77对FireFox *+html 与 *ht

CSS兼容IE6,IE7,FF的技巧

一.CSS HACK 以下两种方法几乎能解决现今所有HACK. 1, !important 随着IE7对!important的支持, !important 方法现在只针对IE6的HACK.(注意写法.记得该声明位置需要提前.) <style> #wrapper { width: 100px!important; /* IE7+FF */ width: 80px; /* IE6 */ } </style> 2, IE6/IE77对FireFox *+html 与 *html 是IE特

让IE和Firefox兼容的CSS技巧集合css hack

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