浏览器兼容


为何会有浏览器兼容问题

因为市场上的浏览器有很多,不同的浏览器内核对网页的解析存在差异,这也是导致浏览器兼容问题出现的主要原因,我们的网页需要在主流浏览器上正常运行,就需要做好浏览器兼容。

处理兼容问题的思路

  1. 是否要做
    • 产品的角度:受众浏览器的比例,效果优先还是基本功能优先
    • 成本的角度
  2. 做到什么程度
    • 让哪些浏览器支持哪些效果
  3. 如何做
    • 根据兼容需求选择技术框架/库

    • 根据兼容需求选择兼容工具:

      html5shiv.js: 解决ie9以下浏览器对html5新增标签的不识别,并导致CSS不起作用的问题。具体用法如下:

      1. 首先在<head>中添加代码:


      2. 然后在CSS中声明这些html5标签为块级元素:
        article,aside,dialog,footer,header,section,footer,nav,figure,menu{display:block}

      respond.js: 让不支持css3 Media Query的浏览器包括IE6-IE8等其他浏览器支持查询。具体用法为在<head>中添加如下代码:


      css reset:它是用来重置(复位)元素在不同核心浏览器下的默认值,尽量保证元素在不同浏览器下的同一“起跑线”,仅此而已,它不是万能的!在不同核心浏览器下,对于css 属性对某些元素的作用呈现出来的偏差,不是CSS reset所能解决的,它只是解决或部分解决元素的默认初始值问题(约定起跑线而已)
      normalize.css:是一种CSS reset的替代方案,它的创造目的有如下几种:

      1. 保护有用的浏览器默认样式而不是完全去掉它们
      2. 一般化的样式:为大部分HTML元素提供
      3. 修复浏览器自身的bug并保证各浏览器的一致性
      4. 优化CSS可用性:用一些小技巧
      5. 解释代码:用注释和详细的文档来

      modernizr:Modernizr是基于渐进增强理论来开发的,所以它支持并鼓励开发者一层一层的创建他们的网站。一切从一个应用了Javascript的空闲地 基开始,一个接一个的添加增强的应用层。因为使用了Modernizr,所以你容易知道浏览器都支持什么。在<html class=“。。。。”>标签添加支持或不支持的class。有的话就直接用,没有的话就用另外的替代。

      postCSS:PostCSS 本身是一个功能比较单一的工具。它提供了一种方式用 JavaScript 代码来处理 CSS。它负责把 CSS 代码解析成抽象语法树结构(Abstract Syntax Tree,AST),再交由插件来进行处理。插件基于 CSS 代码的 AST 所能进行的操作是多种多样的,比如可以支持变量和混入(mixin),增加浏览器相关的声明前缀,或是把使用将来的 CSS 规范的样式规则转译(transpile)成当前的 CSS 规范支持的格式。

    • 条件注释(只针对IE6,7,8,9浏览器)

    • js能力检测: 它的目标是通过javascript识别浏览器的能力

    • CSS hack:CSS hack是通过在CSS样式中加入一些特殊的符号,让不同的浏览器识别不同的符号(什么样的浏览器识别什么样的符号是有标准的,CSS hack就是让你记住这个标准),以达到应用不同的CSS样式的目的,在caniuse中可查看不同属性在浏览器中的兼容情况

  1. 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 有危险/
  2. 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识别 /

渐进增强和优雅降级

渐进增强(progressive enhancement):针对低版本浏览器进行构建页面,保持最基本的功能,然后再针对高级浏览器进行效果,交互等改进和追加功能以达到更好的用户体验(适用于安全性较高的银行网站等)
优雅降级(graceful degradation):一开始就构建完整的功能,再针对低版本浏览器进行兼容(大多数网站开发的思路)

常见属性的兼容情况

inline-block>=ie8
min-width/min-height>=ie8
:before/:after>=ie8
div:hover>=ie7
background-size>=ie9
圆角>=ie9
阴影>=ie9
动画/渐变>=ie10

常见浏览器兼容问题及处理范例

  • 不同浏览器的标签默认的内外边距不同
    问题症状:随便写几个标签,不加样式控制的情况下,不同浏览器的margin 和padding差异较大。
    碰到频率:100%
    解决方案:css里 *{margin:0;padding:0;}
  • 块属性标签float后,又有横向的margin的情况下,在ie6显示margin比设置的大
    问题症状:常见症状是ie6中后面的一块被顶到下一行
    碰到频率:90%
    解决方案:在float的标签样式控制中加入 display:inline;将其转化为行内属性,或者不适用margin,直接改用padding
  • 设置较小高度标签(一般小于10px),在ie6,ie7,遨游中高度超出自己设置高度
    问题症状:在上述浏览器中,部分块元素拥有默认高度(低于16px高度),所以在设置较小高度后对其没有作用。
    碰到频率:60%
    解决方案:1)给元素添加声明:font-size:0;
    2)给元素添加声明:overflow:hidden;
    3)设置行高小于你设计的高度值
    备注:出现这个问题的原因是ie8之前的浏览器都会给标签一个最小默认的行高的高度。即使你的标签是空的,这个标签的高度还是会达到默认的行高。
  • 行内属性标签,设置display:block后采用float布局,又有横行的margin的情况,ie6间距bug(类似第二个问题)
    问题症状:IE6里的间距超过设置的间距
    碰到频率:20%
    解决方案:在display:block;后面加入display:inline;display:table;
  • 图片默认有间距
    问题症状:几个img标签放在一起的时候,有些浏览器会有默认的间距,加上问题一中提到的通配符也不起作用
    碰到频率:20%
    解决方案:使用float属性为img布局
    备注:因为img标签是行内属性标签,所以只要不超出容器宽度,img标签都会排在一行里,但是部分浏览器的img标签之间会有个间距。用float属性去除是最好的方法
  • 浏览器兼容问题六:标签最低高度设置min-height不兼容
    问题症状:因为min-height本身就是一个不兼容的CSS属性,所以设置min-height时不能很好的被各个浏览器兼容
    碰到几率:5%
    解决方案:如果我们要设置一个标签的最小高度200px,需要进行的设置为:{min-height:200px; height:auto !important; height:200px; overflow:visible;}
    备注:在B/S系统前端开发时,有很多情况下我们有这种需求。当内容小于一个值(如300px)时。容器的高度为300px;当内容高度大于这个值时,容器高度被撑高,而不是出现滚动条。这时候我们就会面临这个兼容性问题。
  • 清除浮动

.clearfix:after{
content:"";
display:block;
clear:both;
}
.clearfix{
*zoom:1;
}仅对IE6,7有效,IE6,7中没有:after属性,zoom:1可使其具有相似效果

比如这样一个CSS设置:
div { height: 300px; *height: 200px; _height:100px; }

参考文献:

https://blog.csdn.net/xustart7720/article/details/73604651/
https://blog.csdn.net/flqbestboy/article/details/76599673
https://blog.csdn.net/weixin_38536027/article/details/79375411

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,444评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,421评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,036评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,363评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,460评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,502评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,511评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,280评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,736评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,014评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,190评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,848评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,531评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,159评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,411评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,067评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,078评论 2 352

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,747评论 1 92
  • (方法是:每写一小段代码(布局中的一行或者一块)我们都要在不同的浏览器中看是否兼容,当然熟练到一定的程度就没这么麻...
    Air丹阅读 1,771评论 0 6
  • 一、如何调试 IE 浏览器 IE7以上版本自带的开发者工具,IE6可以用border的方法;例:IE11的开发者工...
    __Qiao阅读 1,126评论 2 17
  • 序章 谈谈“浏览器兼容性”的问题?很多前端的面试或笔试中,都有比较笼统的“说说你所知道的各浏览器存在的兼容问题”,...
    麻辣小隔壁阅读 3,039评论 1 57
  • Ø JavaScript 3 HTML对象获取问题 3 const问题 3 event.x与event.y问题 3...
    DavieKong阅读 475评论 0 1