如何做默认样式重置?resetting 和 normalizing 之间有什么区别?

1.背景介绍

默认样式重置出现的原因:因为现在的浏览器很多,并且每个浏览器都有自己的默认样式,这样就会导致一个页面在多个浏览器下展示产生差异,所以我们需要做一些处理使每个浏览器下展示一致,于是就出现了默认样式重置的说法,可以说,兼容性是CSS reset诞生的的主要原因之一,还有一方面的原因是类似于“库”的作用(.l{float:left}、.r{float:right}为了方便使用)。

最早的一份CSS reset来自Tantek的undohtml.css,很简单的代码,Tantek根据自己的需要,对浏览器的默认样式进行了一些重置。(http://tantek.com/log/2004/undohtml.css)。其余一些有名的CSS reset如业界领袖Eric Meyer的reset(http://meyerweb.com/eric/tools/css/reset/),或是Tripoli Reset(http://monc.se/kitchen/124/introducing-tripoli)。

2.知识剖析

reset是什么?

我们可以把它叫做CSS重设,也有人叫做CSS复位、默认CSS、CSS重置等。CSS重设就是由于各种浏览器解释CSS样式的初始值有所不同,导致设计师在没有定义某个CSS属性时,不同的浏览器会按照自己的默认值来为没有定义的样式赋值,所以我们要先定义好一些CSS样式,去“覆盖”浏览器的CSS默认属性,来让所有浏览器都按照同样的规则解释CSS,这样就能避免发生这种问题。

CSS reset的作用是让各个浏览器的CSS样式有一个统一的基准,而这个基准更多的就是“清零”!如下面常见但事实上极不推荐的代码:

*{ margin:0; padding:0; }

其中*就是常说的通配符,它代表了HTML里面任意一个标签。 如上代码所示,很多人喜欢拿通配符做样式重置,但是对于网站优化而言,使用通配符的做法是非常不可取的,因为这种做法相当消耗浏览器的性能。 原因在于星号代表任意一个标签,当浏览器解析到星号时, 就会将页面中所有用到的标签都进行一次样式重置,不管这个标签是否有这样的默认样式。虽然这种性能消耗可以被忽略不计, 但是做为一个有责任心的web前端开发人员来说,如无必要,通配符还是尽量不要出现在样式重置中。

以下是我找的几个css reset的常用代码,可以参考:

目前比较全的CSS重设(reset)方法总结----

http://blog.bingo929.com/css-reset-collection.html

HTML5 css reset------

http://www.zhangxinxu.com/wordpress/2010/08/html5-css-reset/

CSS工具:重置CSS-----

http://meyerweb.com/eric/tools/css/reset/

几个CSS重置默认样式reset.css代码----

http://www.codefans.net/articles/756.shtml

css重置样式表-----

http://blog.csdn.net/u014516981/article/details/52141451

normalize是什么?

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

github上的源码:https://github.com/necolas/normalize.css

normalize创造的目的

1.保护有用的浏览器默认样式而不是完全去掉它们

2.一般化的样式:为大部分HTML元素提供

3.修复浏览器自身的bug并保证各浏览器的一致性

4.优化CSS可用性

5.解释代码:拥有注释和详细的文档

reset和normalize的区别:

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不会让你的调试工具变的杂乱

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

4. Normalize.css是模块化的

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

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

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

总得来说,CSS Reset是革命党,CSS Reset里最激进那一派提倡不管你有用没用,通通给我脱了衣服,于是*{margin:0;}等等运动,把人家全拍了。看似是众生平等了,实则是浪费了资源又占不到便宜,有求于人家的时候还得给加回去,实在需要人家的默认样式了怎么办?自己看着办吧。

Normalize.css是改良派。他们提倡,各个元素都有其存在的道理,简单粗暴地一视同仁是不好的。谁都有谁的作用,给他们制定个规范,确保他们在任何浏览器里都干好自己的活儿就好了。

来源于‘知乎用户‘(侵删):

https://www.zhihu.com/question/20094066/answer/25004727

3.常见问题

要如何选用reset和normalize?或者直接不用?

4.解决方案

这需要以自身的需求为基点出发去选择,是个公说公有理婆说婆有理的事,故而在此只给出一些建议:

1.如果要使用reset。尽量不要跟风的去直接拷贝CSS reset的代码,自己网站上没用到的不用重置,无意义的重置不要(比如div本不需要{margin:0;padding:0}),尽量使用到的重置是高效简洁的;

2.如果要使用normalize,可以将normalize.css作为自己项目的基础CSS,自定义样式值来满足自己的需求。(例如去掉a标签自带的下划线和p标签的自带的margin)

3.如果选择不用,可以按自己的需要去写适合自身的样式重设代码。

5.编码实战

Demo1-常用标签的默认样式展示:http://119.10.57.69:880/ptt147/Lesson/css-12-ResetAndNormalize/demo1.html

Demo2-用reset代码之后的样式展示:http://119.10.57.69:880/ptt147/Lesson/css-12-ResetAndNormalize/demo2.html

Demo3-用normalize.css之后的样式展示:http://119.10.57.69:880/ptt147/Lesson/css-12-ResetAndNormalize/demo3.html

6.扩展思考

到底该不该用CSS reset?

https://www.zhihu.com/question/23554164

7.参考文献

张鑫旭-《CSS reset的重新审视–避免样式重置》:

http://www.zhangxinxu.com/wordpress/2010/04/css-reset%E7%9A%84%E9%87%8D%E6%96%B0%E5%AE%A1%E8%A7%86-%E9%81%BF%E5%85%8D%E6%A0%B7%E5%BC%8F%E9%87%8D%E7%BD%AE/

作者写的介绍:来,让我们谈一谈Normalize.css

http://jerryzou.com/posts/aboutNormalizeCss/

Normalize.css与传统的CSS Reset有哪些区别?

https://www.zhihu.com/question/20094066/answer/25004727

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,319评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,801评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,567评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,156评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,019评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,090评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,500评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,192评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,474评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,566评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,338评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,212评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,572评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,890评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,169评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,478评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,661评论 2 335

推荐阅读更多精彩内容