服务与支持 |咨询热线 0931-8733767
  • 金城在线
  • 公司简介
  • 发展历程
  • 企业文化
  • 售后服务
  • 工作机会
  • 联系我们

如何使用好css reset

来源:发布时间:2017-11-29 9:44:08

最初出现 CSS reset 的目的是解决浏览器在默认样式上的诸多差异和问题。而现代浏览器在这方面的差异已经小了很多,所以 CSS reset 的必要性就不那么高了。


另一方面,滥用 CSS reset 导致一些问题:


1. 不当的破坏了所有浏览器的基本样式。最典型的混蛋做法就是将所有元素的margin/padding设为0,及去掉ol/ul的列表样式,去掉h1~h6的字体大小样式。这导致blockquote、ol、ul、hn等语义元素在没有赋以其他合理的样式时(常常如此),缺乏恰当的样式展现。而因为视觉上无法区分,这进一步导致许多开发人员忽视或误用这些语义元素,并严重破坏团队内其他希望使用语义元素的开发人员的工作流程。


2. 浏览器为配合控件风格,或出于可用性和无障碍性考虑,会有一些特定的默认样式。如一些浏览器对于 input[type=radio] 默认有 margin,以确保单选框的外观比较协调。粗暴的reset导致控件外观可能在特定浏览器下失调。又如大部分交互控件在获得焦点时有虚线outline。去掉这样式而又不提供其他对于焦点的视觉反馈机制(常常如此)可能导致可用性和无障碍性问题。


3. 某些use case中,网页中有有一些较高独立性的部分,比如内嵌编辑器、widget、第三方内容等,CSS reset导致这部分的样式常需要完全重新覆写,而这种覆写本来可能大部分是不必要的,令人烦躁且可能遗漏。


4. CSS reset 通常会增加浏览器进行样式计算的成本(即有一定的性能负担),因为它引入了许多的针对元素的全局规则,网页中几乎所有元素都会匹配一条乃至几条的reset规则,且往往规则中的属性设定其实会被更specific的规则所覆盖(比如padding和margin)。极端情况下,可能某条reset规则中的所有属性设置实际上并没有在任何元素上生效(因为全部被更specific的规则给覆盖了),所有针对此规则的级联计算全都是浪费。



注意一点,导致这些问题共通的本质性因素是:CSS reset 的作用是全局性的(即缺乏选择器限定范围)。所有合格的程序员都知道避免滥用全局变量,但是在 CSS 上他们就忘记了这一点。


因此,除了上述4点所提到的问题,从可维护性上来看,所有全局变量可能导致的维护性噩梦也会以类似的方式发生在 CSS reset 上。比如一旦引入了 CSS reset,当项目规模大到一定程度,要再想把 CSS reset 从项目中去掉,就十分困难。


最后顺带说下,CSS 3 已加入 unset 关键字和 all 快捷属性(目前仅 Firefox 支持),可以更好的支持必要的 reset 需求。


补充:

有些同学认为“没有那种很傻叉的重置的话,我觉得都算不上是滥用”。问题在于,怎么样算是“傻叉重置”?团队里的每个人对此认识一致吗?将来新人进入老人离开,还能保持对此认识一致吗?


除了非常明确的使用 normalize.css 之类的既定方案的情况,许多团队常见自行 customize 一个 reset.css 或混合了 reset 的 base.css。这种情况下,随着时间流逝最可能出现的情形就是此 css 会逐渐混入了更多的全局性的样式(因为合格的程序员都有增强复用性的冲动),从而陷入之前说的那些问题。因此,未雨绸缪的做法,就是一开始就避免使用 CSS reset,或严格明确和限定其作用(如 normalize 的方式)。


相关文章
  • 预约专家

    为您提供一对一解决方案
    立即预约
  • 售前咨询

    周一至周五9:00——17:30
    立即咨询
  • 联系方式

    13919049954

    全国7×24小时热线服务
  • 免费报价

    专属专业顾问1对1报价
    免费报价