Web前端浏览器兼容初探(转载)
现在看来,之前的想法都是不对的,我们诚然应该追求最新的浏览器使用最新的技术,但是渐进增强,向后兼容的思想一定要有,因为就现在IE6在中国的份额也是不容小视的。
为什么会有兼容问题?
- 使用Trident内核的浏览器:IE、Maxthon、TT;
- 使用Gecko内核的浏览器:Netcape6及以上版本、FireFox;
- 使用Presto内核的浏览器:Opera7及以上版本;
- 使用Webkit内核的浏览器:Safari、Chrome。
而对IE浏览器来说,IE7又是个跨度,因为之前的版本更新甚慢,bug甚多。从IE8开始,IE浏览器渐渐遵循标准,到IE9后由于大家都一致认为标准很重要,可以说在兼容性上比较好了,但是在中国来说,由于xp的占有率问题,使用IE7以下的用户仍然很多,所以我们不得不考虑低版本浏览器的兼容。
对浏览器兼容问题,我一般是这样分类的,HTML,Javascript兼容,CSS兼容。 其中html相关问题比较容易处理,无非是高版本浏览器用了低版本浏览器无法识别的元素,导致其不能解析,所以平时注意一点就是。特别是HTML5增加了许多新标签,低版本浏览器有点影响时代进步啊;
JavaScript兼容性问题
IE:parentElement parentElement.children Firefox:parentNode parentNode.childNodes childNodes的下标的含义在IE和Firefox中不同,Firefox使用DOM规范,childNodes中会插入空白文本节点。一般可以通过node.getElementsByTagName()来回避这个问题。
当html中节点缺失时,IE和Firefox对parentNode的解释不同。例如:
⑦ 关于AJAX的实现上亦有所不同;
让人头疼的CSS兼容
- /* CSS属性级Hack */
- color:red; /* 所有浏览器可识别*/
- _color:red; /* 仅IE6 识别 */
- *color:red; /* IE6、IE7 识别 */
- +color:red; /* IE6、IE7 识别 */
- *+color:red; /* IE6、IE7 识别 */
- [color:red; /* IE6、IE7 识别 */
- color:red\9; /* IE6、IE7、IE8、IE9 识别 */
- color:red\0; /* IE8、IE9 识别*/
- color:red\9\0; /* 仅IE9识别 */
- color:red \0; /* 仅IE9识别 */
- color:red!important; /* IE6 不识别!important 有危险*/
- /* CSS选择符级Hack */
- *html #demo { color:red;} /* 仅IE6 识别 */
- *+html #demo { color:red;} /* 仅IE7 识别 */
- body:nth-of-type(1) #demo { color:red;} /* IE9+、FF3.5+、Chrome、Safari、Opera 可以识别 */
- head:first-child+body #demo { color:red; } /* IE7+、FF、Chrome、Safari、Opera 可以识别 */
- :root #demo { color:red\9; } : /* 仅IE9识别 */
- /* IE条件注释Hack */
- <!--[if IE 6]>此处内容只有IE6.0可见<![endif]-->
- <!--[if IE 7]>此处内容只有IE7.0可见<![endif]-->
② IE6的双倍边距BUG,在块级元素浮动后本来外边距10px,但IE解释为20px,解决办法是加上display: inline ,
也许你会问:“为什么第二个对象和第一个对象之间就不存在双倍边距的BUG”?
4、总结:这个现象仅当块级对象设置了浮动属性后才会出现,内联对象(行级对象)不会出现此问题。并且只有设置左边距和右边距的值才会出问题,上下边距不会出现问题。
margin双布局可以说是IE6下经典的bug之一。产生的条件是:block元素+浮动+margin。
还记得我自认为会css的那个阶段,这个问题我经常碰到,会很熟练的用hack解决这个问题,当时还自以为是,洋洋得意。现在看来,当时的自己嫩的就像个 豆芽菜。真正css厉害的人基本上是不会碰到这个bug的,如果您时不时遇到这个bug,说明您的css还有好一段路要走。
我的体会是越少的浮动,就会越少的代码,会有更灵活的页面,会有扩展性更强的页面。这不多说,归结为到一定水平了,浮动会用的较少。另外,您也会避免使用浮动+margin的用法。所以,越后来越不易遇到这种bug。
这里提一下解决方法,使用hack我是不推荐的,使用hack属于比初学者稍高一点的层次水平。一个页面,没有一个hack,但是各个浏览器下表现一致,这才是水平。使用display:inline;可以解决这个问题。
而为什么display:inline可以解决这个双边距bug,首先是inline元素或inline-block元素是不存在双边距问题的。然后,float:left等浮动属性可以让inline元素haslayout,会让inline元素表现得跟inline-block元素的特性一样, 支持高宽,垂直margin和padding等,所以div class的所有样式可以用在这个display inline的元素上。
③ IE6下图片下方有空隙产生;解决这个BUG的方法也有很多,可以是改变html的排版,或者设置img 为display:block,
④ IE6 3px bug 两个浮动层中间有间隙,这个IE的3PX BUG也是经常出现的,
经典两列布局,float: left;width:200px; 第二个,margin-left,200px; 他们之间会产生3px的间距。
⑤ 在IE6中没有min-width的概念,其默认width就是min-width,所以有时字体过多它会选择撑开容器。
⑥ IE6无法定义1px左右高度的容器,是因为默认的行高造成的,解决的方法也有很多, 例如: overflow:hidden zoom:0.08 line-height:1px
⑦ 使用margin : 0 auto;方法使容器居中依然在IE6中行不通,我们要对其父容器使用
⑧ 被点击访问过的超链接样式不在具有hover和active了,很多人应该都遇到过这个问题, 解决方法是改变CSS属性的排列顺序: L-V-H-A <style type=”text/css”> a:link {} a:visited {} a:hover {} a:active {} /style>
⑨ 在使用绝对定位/相对定位时,设置z-index在ie中可能会失效,是因为其元素依赖于其父元素的z-index,而父元素默认为0 ?所以子元素z-index高,而父元素底,依然不会改变其显示顺序;
10、外边距叠加问题:
该代码会导致外边距叠加,并且外边距跑到div包裹外去,bug是由于块级子元素高度计算方式造成的。
如果haslayout 没有被设置成true,那么元素需依靠某个祖先元素来渲染它。这就是很多的ie bugs诞生的地方。IE浏览器下的很多bug都是haslayout = false 引起的,
- 拥有布局(haslayout=true)元素不会收缩,所以可能会发生文字截断、消失的现象;
- 布局元素对浮动自动清理;
- 相对定位的元素没有布局,这可能导致绝对元素定位偏差;
- 拥有布局的元素外边距不叠加;
- 滚动时,页面会有所跳动;
- 边框消失
- 像素偏差
haslayout不是一个CSS属性,所以我们不能这样的来设置它 haslayout:true;
zoom:1,被认为是最好的触发Layout的方法,因为它对当前元素没有影响。 触发haslayout,相对来说比haslayout=false要简单。
最后,因为各个浏览器对一些元素的默认值设置不一致也会导致表现差异,比如浏览器默认字体,默认行高,默认间距等。所以我们一般会为几个主要元素设置默认值。
浙公网安备 33010602011771号