大家好,我是IT修真院深圳分院第02期学员,一枚正直善良的web程序员。
今天给大家分享一下,修真院官网CSS任务13中有关如何做默认样式的重置?
1.背景介绍
默认样式重置出现的原因:
在日常生活中常用的几个主流浏览器中, 当我们没有给html元素设置样式时,这些浏览器会根据自己的默认样式对html元素进行布局,但是由于每个浏览器的默认布局样式不同, 会导致元素的展示方式出现差异,从而使同一页面在不同浏览器中的展示出现差异。使用CSS样式重置这一方式,就可以使网页展示效果保持 一致。
2.知识剖析
什么是CSS RESET?
在HTML标签在浏览器里有默认的样式,例如 p 标签有上下边距,strong标签有字体加粗样式,em标签有字体倾斜样式。不同浏览器的默认样式之间也会有差别,例如ul默认带有缩进的样式,在IE下,它的缩进是通过margin实现的,而Firefox下,它的缩进是由padding实现的。在切换页面的时候,浏览器的默认样式往往会给我们带来麻烦,影响开发效率。所以解决的方法就是一开始就将浏览器的默认样式全部去掉,更准确说就是通过重新定义标签样式。“覆盖”浏览器的CSS默认属性。最最简单的说法就是把浏览器提供的默认样式覆盖掉!这就是CSS reset。
CSS Reset的作用:
CSS Reset让各个浏览器的CSS样式有一个统一的基准,而实现这一基准最主要的方式就是“清零”
举例:
* { outline: 0; padding: 0; margin: 0; border: 0; } 其中 * 就是常说的通配符,意思是“所有的”。使用 * 代表所有的标签或元素,就叫做通配符选择器。
由于 * 会匹配所有的元素,所以当浏览器解析到 * 时,会将页面内的所有标签都进行如上的样式重置, 这样会影响网页渲染的时间,所以使用 * 时一定要慎重,尽量不要在样式重置时应用 * 。
CSS Reset的一些方法,可以参考我下面贴出的几个链接地址:
什么是NORMALIZE?
Normalize.css 只是一个很小的CSS文件,但它在默认的HTML元素样式上 提供了跨浏览器的高度一致性。相比于传统的CSS reset,Normalize.css 是一种现代的、为HTML5准备的优质替代方案。Normalize.css现在已经被 用于Twitter Bootstrap、HTML5 Boilerplate、GOV.UK、Rdio、CSS Tricks 以及许许多多其他框架、工具和网站上。
normalize创造的目的:
保护有用的浏览器默认样式而不是完全去掉它们
一般化的样式:为大部分HTML元素提供
修复浏览器自身的bug并保证各浏览器的一致性
优化CSS可用性:用一些小技巧
解释代码:用注释和详细的文档来
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 是改良派。他们提倡,各个元素都有其存在的道理, 简单粗暴地一视同仁是不好的。谁都有谁的作用,给他们制定个规范,确保他们 在任何浏览器里都干好自己的活儿就好了。
3.常见问题
Question:reset和normalize如何选用?还是直接不用?
4.解决方案
按需求出发
1.如果要使用reset。则尽量不要去直接拷贝CSS reset的代码, 自己网站上没用到的不用重置,且无意义的重置不要 (比如div本不需要{margin:0;padding:0}), 尽量保证用到的重置是高效简洁的;
2.如果要使用normalize,可以将normalize.css作为自己项目的基础CSS, 自定义样式值来满足自己的需求。(例如去掉a标签自带的下划线和p标签的自带的margin)
3.如果选择不用,可以根据自己需要的再去设置改变,或者写一段适合自己的修改默认样式的代码。
5.编码实战
6.扩展思考
到底该不该用 CSS reset?
7.参考文献
参考一: 张鑫旭-《CSS reset的重新审视 – 避免样式重置》
参考二:来,让我们谈一谈 Normalize.css
参考三:Normalize.css 与传统的 CSS Reset 有哪些区别?
8.更多讨论
讨论【①】:应该如何做到最优的样式重置呢?
讨论【②】:关于张鑫旭提到的“少即是多”,你怎么看?
讨论【③】:移动端的页面样式重置和PC端的一样吗?
ppt链接:https://ptteng.github.io/PPT/PPT/CSS-13-Restting&Normalizing.html#/
视频链接:https://v.qq.com/x/page/q0531azgso7.html
鸣谢
感谢大家观看
BY : 杨梦桐&孙剑立
今天的分享就到这里啦,欢迎大家点赞、转发、留言、拍砖~
------------------------------------------------------------------------------------------------------------------------
技能树.IT修真院
“我们相信人人都可以成为一个工程师,现在开始,找个师兄,带你入门,掌控自己学习的节奏,学习的路上不再迷茫”。
这里是技能树.IT修真院,成千上万的师兄在这里找到了自己的学习路线,学习透明化,成长可见化,师兄1对1免费指导。快来与我一起学习吧 !
请点击链接【修真院】