美文网首页饥人谷技术博客
浏览器兼容的部分问题

浏览器兼容的部分问题

作者: 汤初景 | 来源:发表于2017-08-05 22:01 被阅读0次

    什么是 CSS hack

    由于不同厂商的浏览器,比如Internet Explorer,Safari,Mozilla Firefox,Chrome等,或者是同一厂商的浏览器的不同版本,如IE6和IE7,对CSS的解析认识不完全一样,因此会导致生成的页面效果不一样,得不到我们所需要的页面效果。CSS hack 就是这种情况下我们针对不同的浏览器去写不同的CSS的一个过程,让它能够同时兼容不同的浏览器,能在不同的浏览器中也能得到我们想要的页面效果。


    谈一谈浏览器兼容的思路

    1. 要不要做
    • 产品的角度(产品的受众、受众的浏览器比例、效果优先还是基本功能优先)
    • 成本的角度 (有无必要做某件事)
    1. 做到什么程度
    • 让哪些浏览器支持哪些效果
    1. 如何做

    列举几种浏览器兼容的写法

    1. 条件注释 (conditional comment) 是于HTML源码中被IE有条件解释的语句。条件注释可被用来向IE提供及隐藏代码。
    <!--[if IE 6]>
        <p>You are using Internet Explorer 6.</p>
        <![endif]-->
        <!--[if !IE]><!-->
        <script>alert(1);</script>
        <!--<![endif]-->
        <!--[if IE 8]>
        <link href="ie8only.css" rel="stylesheet">
        <![endif]-->                                                         <!--IE10不支持条件注释-->
    
    项目 范例 说明
    [if !IE] 非IE
    lt [if lt IE 5.5] 小于IE 5.5
    lte [if lte IE 6] 小于等于IE6
    gt [if gt IE 5] 大于 IE5
    gte [if gte IE 7] 大于等于IE7
    1. CSS hack
    .box{
      color: red;
      _color: blue; /*ie6*/
      *color: pink; /*ie67*/
      color: yellow\9;  /*ie/edge 6-8*/
    }
    
    <!–-[if IE 7]>
    <link rel="stylesheet" href="ie7.css" type="text/css" />
    <![endif]–->
    

    一些与兼容有关的工具
    html5shiv.js
    respond.js
    Modernizr


    名词解释

    • 条件注释
      条件注释是于HTML源码中被 IE 有条件解释的语句。条件注释可被用来向 IE提供及隐藏代码。IE10以下支持。

    • IE Hack
      利用不同版本的 IE 的漏洞,做到兼容IE低版本。

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

    • html5shiv.js
      html5shiv.js主要解决HTML5提出的新的元素不被IE6-8识别,这些新元素不能作为父节点包裹子元素,并且不能应用CSS样式。让CSS 样式应用在未知元素上只需执行 document.createElement(elementName) 即可实现。

    • respond.js
      Respond.js 是一个小脚本,用于为 IE6-8 以及其它不支持 CSS3 媒体查询功能的浏览器提供媒体查询的 min-width 和 max-width 特性,实现响应式网页设计。

    • css reset
      强制重置浏览器默认样式

    • normalize.css
      是作为css reset的改良版,没有暴力的把所有浏览器默认样式都去掉,而是保护了有用的默认浏览器样式,一般化了大部分html样式,修复了浏览器自身的bug,优化了css的可用性。

    • Modernizr
      Modernizr 使你可以方便地为各种情况编写 JavaScript 和 CSS,无论浏览器是否支持这些特性。这是处理渐进增强的完美方案。Modernizr 会在页面加载后立即检测特性;然后创建一个包含检测结果的 JavaScript 对象,同时在 html 元素加入方便你调整 CSS 的 class 名。

    • postCSS
      它可以被理解为一个平台,可以让一些插件在上面跑,它提供了一个解析器,可以将CSS解析成抽象语法树,通过PostCSS这个平台,我们能够开发一些插件,来处理CSS。热门插件如autoprefixer,它可以帮我们处理兼容问题,只需正常写CSS,autoprefixer可以帮我的自动生成兼容性代码


    查询属性兼容性的网站caniuse.com

    相关文章

      网友评论

        本文标题:浏览器兼容的部分问题

        本文链接:https://www.haomeiwen.com/subject/cimwlxtx.html