Normalize vs Reset

2. Normalize vs Reset

2.3 css reset 和 normalize.css 有什么区别?

2.3.1 创造 normalize.css 的几个目的

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

2.3.2 Normalize vs Reset

  1. Normalize.css 保护了有价值的默认值
    Reset 通过为几乎所有的元素施加默认样式,强行使得元素有相同的视觉效果。相比之下,Normalize.css 保持了许多默认的浏览器样式。这就意味着你不用再为所有公共的排版元素重新设置样式。当一个元素在不同的浏览器中有不同的默认值时,Normalize.css 会力求让这些样式保持一致并尽可能与现代标准相符合。

  2. Normalize.css 修复了浏览器的 bug
    它修复了常见的桌面端和移动端浏览器的 bug。这往往超出了 Reset 所能做到的范畴。关于这一点,Normalize.css 修复的问题包含了 HTML5 元素的显示设置、预格式化文字的 font-size 问题、在 IE9 中 SVG 的溢出、许多出现在各浏览器和操作系统中的与表单相关的 bug。

    可以看以下这个例子,看看对于 HTML5 中新出现的 input 类型 search,Normalize.css 是如何保证跨浏览器的一致性的。

    /**
    *1.  Addresses appearance set to searchfield in S5, Chrome
    * 2.  Addresses box-sizing set to border-box in S5, Chrome (include -moz to future-proof)
    */
    
    input[type='search'] {
      -webkit-appearance: textfield; //1
      -moz-box-sizing: content-box;
      -webkit-box-sizing: content-box; //2
      box-sizing: content-box;
    }
    /**
      *Removes inner padding and search cancel button in S5, Chrome on OS X
     */
    input[type='search']::-webkit-search-decoration,
    input[type='search']::-webkit-search-cancel-button {
      -webkit-appearance: none;
    }
    
  3. Normalize.css 不会让你的调试工具变的杂乱
    使用 Reset 最让人困扰的地方莫过于在浏览器调试工具中大段大段的继承链,如下图所示。在 Normalize.css 中就不会有这样的问题,因为在我们的准则中对多选择器的使用时非常谨慎的,我们仅会有目的地对目标元素设置样式。

  4. Normalize.css 是模块化的
    这个项目已经被拆分为多个相关却又独立的部分,这使得你能够很容易也很清楚地知道哪些元素被设置了特定的值。因此这能让你自己选择性地移除掉某些永远不会用到部分(比如表单的一般化)。

  5. Normalize.css 拥有详细的文档
    Normalize.css 的代码基于详细而全面的跨浏览器研究与测试。这个文件中拥有详细的代码说明并在 Github Wiki 中有进一步的说明。这意味着你可以找到每一行代码具体完成了什么工作、为什么要写这句代码、浏览器之间的差异,并且你可以更容易地进行自己的测试。

这个项目的目标是帮助人们了解浏览器默认是如何渲染元素的,同时也让人们很容易地明白如何改进浏览器渲染。

你可能感兴趣的:(CSS)