Skip to content

浏览器兼容 #13

@Leon68

Description

@Leon68

什么是 CSS hack

由于不同厂商的流览器或某浏览器的不同版本(如IE6-IE11,Firefox/Safari/Opera/Chrome等),对CSS的支持、解析不一样,导致在不同浏览器的环境中呈现出不一致的页面展现效果。这时,我们为了获得统一的页面效果,就需要针对不同的浏览器或不同版本写特定的CSS样式,我们把这个针对不同的浏览器/不同版本写相应的CSS code的过程,叫做CSS hack!
参考

谈一谈浏览器兼容的思路

要不要做

产品的角度(产品的受众、受众的浏览器比例、效果优先还是基本功能优先)

成本的角度 (有无必要做某件事)

  • 做到什么程度
  • 让哪些浏览器支持哪些效果

如何做

  • 根据兼容需求选择技术框架/库(jquery)
  • 根据兼容需求选择兼容工具(html5shiv.js、respond.js、css reset、normalize.css、Modernizr)
  • postCSS
  • 条件注释、CSS Hack、js 能力检测做一些修补

渐进增强和优雅降级

渐进增强(progressive enhancement): 针对低版本浏览器进行构建页面,保证最基本的功能,然后再针对高级浏览器进行效果、交互等改进和追加功能达到更好的用户体验
优雅降级 (graceful degradation): 一开始就构建完整的功能,然后再针对低版本浏览器进行兼容。

列举5种以上浏览器兼容的写法

CSS hack方式一:条件注释法

 
这种方式是IE浏览器专有的Hack方式,微软官方推荐使用的hack方式。举例如下

只在IE下生效
<!--[if IE]>
这段文字只在IE浏览器显示
<![endif]-->

只在IE6下生效
<!--[if IE 6]>
这段文字只在IE6浏览器显示
<![endif]-->

只在IE6以上版本生效
<!--[if gte IE 6]>
这段文字只在IE6以上(包括)版本IE浏览器显示
<![endif]-->

只在IE8上不生效
<!--[if ! IE 8]>
这段文字在非IE8浏览器显示
<![endif]-->

非IE浏览器生效
<!--[if !IE]>
这段文字只在非IE浏览器显示
<![endif]-->

CSS hack方式二:类内属性前缀法

属性前缀法是在CSS样式属性名前加上一些只有特定浏览器才能识别的hack前缀,以达到预期的页面展现效果。
“-″减号是IE6专有的hack
“\9″ IE6/IE7/IE8/IE9/IE10都生效
“\0″ IE8/IE9/IE10都生效,是IE8/9/10的hack
“\9\0″ 只对IE9/IE10生效,是IE9/10的hack

CSS hack方式三:选择器前缀法

选择器前缀法是针对一些页面表现不一致或者需要特殊对待的浏览器,在CSS选择器前加上一些只有某些特定浏览器才能识别的前缀进行hack。

目前最常见的是

*html *前缀只对IE6生效
*+html *+前缀只对IE7生效
@media screen\9{...}只对IE6/7生效
@media \0screen {body { background: red; }}只对IE8有效
@media \0screen,screen\9{body { background: blue; }}只对IE6/7/8有效
@media screen\0 {body { background: green; }} 只对IE8/9/10有效
@media screen and (min-width:0\0) {body { background: gray; }} 只对IE9/10有效
@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {body { background: orange; }} 只对IE10有效

CSS3选择器结合JavaScript的Hack

用IE10进行举例:

由于IE10用户代理字符串(UserAgent)为:Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.2; Trident/6.0),所以我们可以使用JavaScript将此属性添加到文档标签中,再运用CSS3基本选择器匹配。

JavaScript代码:

var htmlObj = document.documentElement;
htmlObj.setAttribute('data-useragent',navigator.userAgent);
htmlObj.setAttribute('data-platform', navigator.platform );

CSS3匹配代码:

html[data-useragent*='MSIE 10.0'] #id {
color: #F00;
}

以下工具/名词是做什么的

  • 条件注释
    条件注释 (conditional comment) 是于HTML源码中被IE有条件解释的语句。条件注释可被用来向IE提供及隐藏代码。
    适用于优雅降级向下兼容,使其兼容IE6 IE7 IE8

  • IE Hack
    针对不同的浏览器去写不同的CSS,让它能在不同的浏览器中也能得到我们想要的页面效果,主要有
    1 属性前缀法
    利用不同浏览器的bug来识别浏览器,然后对该浏览器加入样式
    如IE6能识别下划线"_和星号" ",IE7能识别星号" ",但不能识别下划线"",IE6~IE10都认识"\9"
    2 选择器前缀法
    3 IE条件注释法

  • js 能力检测
    能力检测的目标不是识别特定的浏览器,而是识别浏览器的能力。使用这种方式无需顾及浏览器如何如何,只需确定浏览器是否支持特定的能力,就可以给出相关的方案。

  • html5shiv.js
    解决IE6 7 8 Safari 4.x (iPhone 3.x) 以及Firefox 3.x不支持html5的新特性和新标签问题

  • respond.js
    在IE6 7 8上模拟CSS3的媒体查询功能

  • css reset
    通过CSS重置浏览器默认样式

  • normalize.css
    Normalize.css是一种CSS reset的替代方案,是温和版的CSS reset。在默认的HTML元素样式上提供了跨浏览器的高度一致性。
    保护有用的浏览器默认样式而不是完全去掉它们
    为大部分HTML元素提供统一化样式
    修复了常见的桌面端和移动端浏览器的bug并保证各浏览器的一致性
    用一些小技巧优化CSS可用性
    用注释和详细的文档来解释代码

  • Modernizr
    浏览器功能检测以确定浏览器是否支持各种html5和css3特性,引用Modernizr生效之后,它会给html元素添加一批css的class名称,这些class名称标记当前浏览器支持哪些特性和不支持哪些特性,支持的特性就直接显示该天特性的名称作为一个class(例如:canvas,websockets),不支持的特性显示的class是“no-特性名称”(例如:no-flexbox)。这样我们在写CSS的时候就可以直接使用Modernizr在元素里生成的class名称,定义相应的属性以便支持当前浏览器。

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

一般在哪个网站查询属性兼容性?

caniuse.com查询css兼容性
browse.hacks查询Hacks写法

常见属性的兼容情况:

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

Metadata

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions