html 常见的兼容性问题

🌙
手机阅读
本文目录结构
axihe

png24 位的图片在 iE6 浏览器上出现背景

解决方案:做成 PNG8,也可以引用一段脚本处理。

浏览器默认的 margin 和 padding 不同

解决方案:加一个全局的 *{margin:0;padding:0;} 来统一。

IE6 双边距 bug

在 IE6 下,如果对元素设置了浮动,同时又设置了 margin-left 或 margin-right,margin 值会加倍。

#box{ float:left; width:10px; margin:00010px;}

这种情况之下 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 识别*/
}

IE 下,获取自定义属性用获取常规

IE 下,可以使属性的方法来获取自定义属性用获取常规,也可以使用 getAttribute() 获取自定义属性;

Firefox 下,只能使用 getAttribute() 获取自定义属性

解决方法:统一通过 getAttribute() 获取自定义属性

event 对象的区别

IE 下,event 对象有 x、y 属性,但是没有 pageX、pageY 属性;

Firefox 下,event 对象有 pageX、pageY 属性,但是没有 x、y 属性

解决方法:(条件注释)缺点是在 IE 浏览器下可能会增加额外的 HTTP 请求数。

Chrome 12px 像素

Chrome 中文界面下默认会将小于 12px 的文本强制按照 12px 显示

解决方法:可通过加入 CSS 属性 -webkit-text-size-adjust: none; 解决

hover 和 active 失效

超链接访问过后 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 图片格式支持不好

解决方案:引用一段脚本处理

更多面试题

如果你想了解更多的前端面试题,请点击下面进行选择,这里基本包涵了市场上的所有前端方面的面试题,让你面试更加顺利。

这些题库还在更新中,如果你有不错的面试题库欢迎分享给我,我整理后放上来;人人为我,我为人人,互帮互助,共同提高,祝大家都拿到心仪的Offer!


AXIHE / 精选资源

浏览全部教程

面试题

学习网站

前端培训
自己甄别

前端书籍

关于朱安邦

我叫 朱安邦,阿西河的站长,在杭州。

以前是一名平面设计师,后来开始接接触前端开发,主要研究前端技术中的JS方向。

业余时间我喜欢分享和交流自己的技术,欢迎大家关注我的 Bilibili 和抖音。

关注我: Github / 知乎

如果你加我的私人微信,麻烦写上您的 称呼,所在地区,职业,方便我备注,谢谢


本站的微信公众号

阿西河前端教程

Anbang

安邦的私人微信

微信号: yaolushan

Anbang

Bilibili(B站)

朱安邦

Anbang