浅谈Normalize.css和Reset.css的区别——选择对的默认样式处理脚本

Normalize.css 只是一个很小的CSS文件,但它在默认的HTML元素样式上提供了跨浏览器的高度一致性。相比于传统的CSS resetNormalize.css是一种现代的、为HTML5准备的优质替代方案。Normalize.css现在已经被用于Twitter Bootstrap、HTML5 Boilerplate、GOV.UK、Rdio、CSS Tricks 以及许许多多其他框架、工具和网站上。

Normalize.css 项目地址

Normalize.css 在GitHub上的源码

Normalize.css保护了有价值的浏览器默认值

react.css中所有元素样式被统一,没有个性,强行使得元素有相同的视觉效果,全部依赖于往后为元素单独设置的样式。

Normalize.css保护了有价值的浏览器默认样式,跟不加Normalize.css样式的时候差别不大,但是消除了浏览器之间的差异,保证了各个浏览器兼容性。

Normalize.css修复了浏览器自身bug

Normalize.css修复了常见的桌面端和移动端浏览器的bug。包含了HTML5元素的显示设置、预格式化文字的font-size问题、在IE9中SVG的溢出、许多出现在各浏览器和操作系统中的与表单相关的bug。

Normalize.css 拥有详细的文档

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

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

Normalize.css 不会让你的调试工具变的杂乱

使用Reset最让人困扰的地方莫过于在浏览器调试工具中大段大段的继承链,如下图所示。在Normalize.css中就不会有这样的问题,因为在Normalize.css的准则中对多选择器的使用是非常谨慎的,仅会有目的地对目标元素设置样式。

Normalize.css 是模块化的

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

参考文章

CSS reset的重新审视 – 避免样式重置

与君共勉:再牛逼的梦想,也抵不住傻逼般的坚持!

你可能感兴趣的:(前端开发,-,CSS,/,CSS3)