转:浏览器兼容
1. 什么是 CSS hack
CSS hack 由于不同厂商的浏览器,比如 Internet Explorer,Safari,Mozilla Firefox,Chrome 等,或者是同一厂商的浏览器的不同版本,如 IE6 和 IE7,对 CSS 的解析认识不完全一样,因此会导致生成的页面效果不一样,得不到我们所需要的页面效果。 这个时候我们就需要针对不同的浏览器去写不同的 CSS,让它能够同时兼容不同的浏览器,能在不同的浏览器中也能得到我们想要的页面效果。
简单的说,CSS hack 的目的就是使你的 CSS 代码兼容不同的浏览器。当然,我们也可以反过来利用 CSS hack 为不同版本的浏览器定制编写不同的 CSS 效果。
CSS Hack 大致有三种表现形式 :
- css 属性前缀法
- 选择器前缀法
- IE 条件注释法
2. 谈一谈浏览器兼容的思路
- 1. 要不要做
产品的角度(产品的受众,受众的浏览器比例,效果优先还是基本功能优先)
成本的角度(有无必要做某件事情)
- 2. 做到什么程度
让哪些浏览器去支持哪些效果
-
3. 如何做
1. 根据兼容需求选择技术框架 / 库(Bootstrap (>=ie8),jQuery 1 (>=ie6), jQuery 2 (>=ie9),vue (>= ie9)
2. 根据兼容需求选择兼容工具 (html5shiv.js/respond.js/css reset/normalize.css/modernizr/postCSS)
3. 条件注释 / css Hack/js 能力检测做一些修补
-
4. 关于浏览器兼容的应对策略 (渐进增强和优雅降级)
渐进增强 progressive enhancement:
概念:针对低版本浏览器进行构建页面,保证最基本的功能,然后再针对高级浏览器进行效果、交互等改进和追加功能达到更好的用户体验。
观点:"渐进增强" 观点认为应关注于内容本身。
内容是我们建立网站的诱因。有的网站展示它,有的则收集它,有的寻求,有的操作,还有的网站甚至会包含以上的种种,但相同点是它们全都涉及到内容。这使得 "渐进增强" 成为一种更为合理的设计范例。这也是它立即被 Yahoo! 所采纳并用以构建其 "分级式浏览器支持 (Graded Browser Support)" 策略的原因所在。
优雅降级 graceful degradation:
概念:一开始就构建完整的功能,然后再针对低版本浏览器进行兼容。
观点:"优雅降级" 观点认为应该针对那些最高级、最完善的浏览器来设计网站。而将那些被认为 "过时" 或有功能缺失的浏览器下的测试工作安排在开发周期的最后阶段,并把测试对象限定为主流浏览器(如 IE、Mozilla 等)的前一个版本。
在这种设计范例下,旧版的浏览器被认为仅能提供 "简陋却无妨 (poor, but passable)" 的浏览体验。你可以做一些小的调整来适应某个特定的浏览器。但由于它们并非我们所关注的焦点,因此除了修复较大的错误之外,其它的差异将被直接忽略。
区别:优雅降级是从复杂的现状开始,并试图减少用户体验的供给,而渐进增强则是从一个非常基础的,能够起作用的版本开始,并不断扩充,以适应未来环境的需要。降级(功能衰减)意味着往回看;而渐进增强则意味着朝前看,同时保证其根基处于安全地带。
3. 浏览器兼容的写法
-
属性前缀法 (即类内部 Hack)
例如 IE6 能识别 -, 下划线, 星号,IE7 能识别星号 *,但不能识别 -, 下划线, IE6~IE10 都认识 \ 9,但 firefox 前述三个都不能认识
- box {
- color: red;
- _color: blue;
- /*ie6*/
- * color: pink;
- /*ie67*/
- color: yellow\9;
- /*ie/edge 6-8*/
- }
- 选择器前缀法
- * 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有效
-
条件注释法
这种方式是 IE 浏览器专有的 Hack 方式,微软官方推荐使用的 hack 方式
-
-
-
-
- <!--[if !IE]>
- 这段文字只在非IE浏览器显示
- <![endif]-->
4. 以下工具 / 名词是做什么的
-
条件注释
条件注释 是于 HTML 源码中被 IE 有条件解释的语句。条件注释可被用来向 IE 提供及隐藏代码。 条件注释最初于微软的 Internet Explorer 5 浏览器中出现,并且直至 Internet Explorer 9 均支持。微软已宣布于 IE10 停止支持。具体代码如上已给出。
-
IE Hack
针对 IE 浏览器编写不同的 CSS 的让 IE 能够正常渲染的过程
-
js 能力检测
能力检测又称特性检测。能力检测的目的不是识别具体的浏览器,而是识别浏览器的能力。
能力检测的目的应该是根据你需要的特性来选择问题的解决方案,而不是检测用户在用什么浏览器。而且在检测时要保证你要用到的能力确实存在,自己不要做过多的推测,代码也不要做过多的判断。
两个重要的概念:
第一个概念是先检测达成目的的最常用的特性。先检测最常用的特性,可以保证代码最优化,因为在多数情况下都可以避免测试多个条件。
第二个概念是必须测试实际要用到的特性。一个特性存在,不一定意味着另一个特性也存在。
-
html5shiv.js
IE 9 之前的版本几乎不支持 HTML5 元素和其它 HTML5 特性。
HTML5 Shiv 支持在旧版 Internet Explorer(IE9 之前)中使用 HTML5 细分元素,并为 Internet Explorer 6-9,Safari 4.x(和 iPhone 3.x)和 Firefox 3.x 提供基本的 HTML5 样式。
- respond.js
响应式布局,理想状态是,对 PC / 移动各种终端进行响应。媒体查询的支持程度是 IE9 + 以及其他现代的浏览器,但是 IE8 在市场当中仍然占据了比较大量的市场份额,使我们不得不进行 IE 低端浏览器的考虑。那么如何在 IE6~8 浏览器中兼容响应式布局呢?这里我们需要借助这样一个文件:respond.js
Respond.js 是一个快速、轻量的 polyfill,用于为 IE6-8 以及其它不支持 CSS3 Media Queries 的浏览器提供媒体查询的 min-width 和 max-width 特性,实现响应式网页设计。
-
normalize.css
normalize.css 是 reset.css 的替代方案,保留有用的浏览器默认样式,同时进行一些 bug 的修复。相对平和
-
Modernizr
Modernizr 是一套 JavaScript 库,用来侦测浏览器是否支持 CSS3 或 HTML5 功能支持情况等。如果浏览器不支持,Modernizr 会使用其他的解决方法来进行模拟。
Modernizr 会在页面加载后立即检测特性;然后创建一个包含检测结果的 JavaScript 对象,同时在 html 元素加入方便你调整 CSS 的 class 名。
- postCSS
PostCSS 是一个使用 JS 插件转换样式的工具。这些插件可以删除您的 CSS,支持变量和混合,透明未来的 CSS 语法,内联图像等。
PostCSS 不是预处理器本身; 它不会转换 CSS。事实上,它本身根本不做任何事。它所做的是提供一个 CSS 解析器和一个框架,用于创建可以分析,lint,处理资产,优化,创建回退,否则转换解析的 CSS 的插件。PostCSS 将 CSS 解析为抽象语法树(AST),通过一系列插件将其传递,然后 PostCSS 核心为插件更改的树生成一个新的 CSS 字符串。。如果你熟悉 JavaScript 工具,那么你可以认为 PostCSS 为 CSS 的 Babel。
PostCSS 目前有 200 多个插件,其中很多在 PostCSS GitHub 页面上列出,而其他的可以在有用的 PostCSS 目录 postcss.parts 中找到。PostCSS 可以集成在大多数构建工具中,包括 Gulp,Grunt,webpack 或 npm。
PostCSS 被行业领导者使用,包括维基百科,Twitter,阿里巴巴和 JetBrains。该 Autoprefixer PostCSS 插件是最流行的 CSS 处理器之一。
5. 一般在哪个网站查询属性兼容性?
来源: http://www.bubuko.com/infodetail-2004322.html