前端面试题总结【18】:html常见兼容性问题?
-
png24位的图片在iE6浏览器上出现背景
解决方案:做成PNG8,也可以引用一段脚本处理. -
浏览器默认的
margin和padding不同
解决方案:加一个全局的*{margin:0;padding:0;}来统一。 -
IE6双边距bug:在IE6下,如果对元素设置了浮动,同时又设置了margin-left或margin-right,margin值会加倍。
#box{ float:left; width:10px; margin:0 0 0 10px;}
这种情况之下IE会产生20px的距离
解决方案:在float的标签样式控制中加入 _display:inline; 将其转化为行内属性。( _ 这个符号只有ie6会识别)
- 渐进识别的方式,从总体中逐渐排除局部。
首先,巧妙的使用“\9”这一标记,将IE游览器从所有情况中分离出来。
接着,再次使用 "+" 将IE8和IE7、IE6分离开来,这样IE8已经独立识别。
.bb{
background-color:#f1ee18; /*所有识别*/
.background-color:#00deff\9; /*IE6、7、8识别*/
+background-color:#a200ff; /*IE6、7识别*/
_background-color:#1e0bd1; /*IE6识别*/
}
5.IE下,可以使用获取常规属性的方法来获取自定义属性,也可以使用 getAttribute() 获取自定义属性;Firefox下,只能使用getAttribute()获取自定义属性
解决方法:统一通过getAttribute()获取自定义属性
-
IE下,event对象有x、y属性,但是没有pageX、pageY属性;Firefox下,event对象有pageX、pageY属性,但是没有x、y属性
解决方法:(条件注释)缺点是在IE浏览器下可能会增加额外的HTTP请求数。 -
Chrome中文界面下默认会将小于12px的文本强制按照12px显示
解决方法:可通过加入CSS属性-webkit-text-size-adjust: none; 解决 -
超链接访问过后
hover样式就不出现了,被点击访问过的超链接样式不在具有hover和active了
解决方法:改变CSS属性的排列顺序L-V-H-A
a:link {}
a:visited {}
a:hover {}
a:active {}
-
怪异模式问题:漏写
DTD声明,Firefox仍然会按照标准模式来解析网页,但在IE中会触发怪异模式。为避免怪异模式给我们带来不必要的麻烦,最好养成书写DTD声明的好习惯。现在可以使用html5 推荐的写法:<!DOCTYPE html> -
上下
margin重合问题:ie和ff都存在,相邻的两个div的margin-left和margin-right不会重合,但是margin-top和margin-bottom却会发生重合。
解决方法:养成良好的代码编写习惯,同时采用margin-top或者同时采用margin-bottom。 -
ie6对png图片格式支持不好
解决方案:引用一段脚本处理
推荐:
- 持续更新,致力于做一个持久的搬运工!
- 下面是已经整理好的面试题PDF获取和相关进阶学习书籍资料地址,有需求戳一下
- 2020前端面试题总结合集