请问CSS清零代码用哪一套哦,网上好多

html-css015

请问CSS清零代码用哪一套哦,网上好多,第1张

这个东西没有一个标准答案,网上的不一定适合自己的项目,一般是下载一套标准的css reset,然后在此基础上根据自己实际情况去删改的。

目前比较有名的css reset有4种,按热度排列如下:

Eric Meyer’s “Reset CSS” 2.0

Yahoo! (YUI 3) Reset CSS

Universal Selector ‘*’ Reset

Normalize.css 1.0

一般用1或2,我个人是喜欢用第2个的。

Normalize对比Reset的优势对比:

CSS Reset的核心作用就是清零,而且过于暴力;那么作为后者Normalize.css,到底有什么优势可以完全取代CSS Reset呢?

1.Normalize.css 保护了有价值的默认值

Reset通过为几乎所有的元素施加默认样式,强行使得元素有相同的视觉效果。

相比之下,Normalize.css保持了许多默认的浏览器样式。 这就意味着你不用再为所有公共的排版元素重新设置样式。

当一个元素在不同的浏览器中有不同的默认值时,Normalize.css会力求让这些样式保持一致并尽可能与现代标准相符合。

2.Normalize.css 修复了浏览器的bug

它修复了常见的桌面端和移动端浏览器的bug。这往往超出了Reset所能做到的范畴。

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

3.Normalize.css 修复了浏览器的bug

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

4.Normalize.css 是模块化的

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

5.Normalize.css 拥有详细的文档

Normalize.css的代码基于详细而全面的跨浏览器研究与测试。这个文件中拥有详细的代码说明并在Github

Wiki中有进一步的说明。这意味着你可以找到每一行代码具体完成了什么工作、为什么要写这句代码、浏览器之间的差异,并且你可以更容易地进行自己的测试。

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

源码解析

Normalize.css 是一个可定制的 CSS 文件,使浏览器呈现的所有元素,更一致和符合现代标准是在现代浏览器环境下对于

CSS reset的替代。 它正是针对只需要统一的元素样式。该项目依赖于研究浏览器默认元素风格之间的差异,精确定位需要重置的样式。 这是一个现代

ul和li标签默认会带有margin和padding值的,所以一般在css里面会把它们默认自带的内外边距给清零,然后再定义它们的样式。例如你的这段CSS,可以在body的样式后面加多一个:

ul,li {margin:0padding:0}

这样对ul和li定义样式的时候就不会受到默认属性的干扰了。