CSS全局污染——咋整

为什么要写这篇文?

我们都知道css通过选择器可以填写键值对的格式来修改html元素的样式。一般我们都会用标签,id, class的选择器。其中class是最多的。起码我个人开发时便是这样。我们也知道class是可以加在一个或者多个的html元素上,并且也允许一个css文件中,存在两个class名字一样的样式,比如以下的代码。(图1)


图1


这样是可以生效的。那么,我们可以联想一下。当我们和别人合作时,一个人负责了一个部分的页面,你负责一个部分的页面,你们不约而同起了一个名字一摸一样的class, 但又是写了不一样的样式。那么,当html文件引入这两个css文件时,就会出现一些css全局污染的错误。当项目变得特别巨大时,就会很麻烦去fix这个bug,也有可能为了修这一个bug又引发了新的bug。那么这个时候,我们应该怎么让我们前端的同学们愉快地放心地去写css,并完成一个可维护的项目呢。以下就列举出本人的一些经验。

第一个:scoped 属性

html5给我们带来了很多很强势的功能,让我们更好地实现我们想实现的想法。其中scoped属性则可以让我们更好地控制css的样式。让其变成局部的,我们可以这样写。(图二)


图二

但是呢,根据这个同学的博客和本人测试,在chrome下是无效的。只有在firefox下才有效。这就困难到我们了,我们开发网页,其中一个要求就是无论在哪个浏览器,都能很好地展示出我们的作品。不方,解决的办法总比问题多。

第二个:css in js

不知道为何,我个人是很推崇这个方式。也许很多人觉得css html js 应该分开独立的三份,各司其职。但是,我觉得有时候为了改一点东西,我得三个文件去改。。而且当项目大的时候,更是头疼,看着那么多文件,脑袋都炸了。如果能放到一起,岂不是很容易维护。扯远了,css in js 就像react的jsx语法一样。用js来写css。在react中呢,你可以顶一个一个对象,里面有很多你需要的样式。然后利用react的style,传对应的style对象进去。就类似这样(图3)


图3

那么这样,我们都不需要为某个dom来取一个class的名字, 怎么会还存在css全局污染的问题呢?对吧!对于css in js, 有兴趣的同学可以自行去谷歌一些相关的资料来学习,这里就不太继续丰富下去。其实我上面说的,已经可以让你大概了解这是什么。

第三个:CSS Modules

我们现在的网页开发,已经是一个组件化,模块化的时代。为什么要组件化,模块化呢?首先,我们的网页其实就是可以分成好几个组件,一个网页是由好几个部分组合组成,就像造楼房一样。那么我们就可以利用拆解的思想去将一个页面去分成几个部分。而这个部分就是组件。这样有利于让整个页面结构尤其清晰,也会让你开发有所方向, 能一个一个组件来,而不会一股脑写一堆,其实你什么都只做了一点。css modules 就是一个把css也模块化的技术。它很简单,真的。具体的你可以看一下 阮一峰老师的教程,传送门。我一般在写react项目时,如果项目比较大时,是优先使用css modules的,因为这样可以很好解决css全局污染的问题, 让你可以更容易地起了类名,又不用怕和别的模块的css类名冲突,更专注于编码。再者就是方便维护了,哪个模块有问题,哪个模块的所有的代码都在一处,你很容易找到事故发生地方,极大地提高效率。


以上是我开发web应用时,解决css全局污染的一些办法。无论是团队,还是个人,fix这个问题,都会极大提高开发效率和降低以后的维护成本。如果想要深入了解和学习,可以自行谷歌,网上有比我更好的教程。当然,你有更好的方法,欢迎评论。

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

推荐阅读更多精彩内容