react CSS Modules

前提

項(xiàng)目是采用create-react-app 搭建的腳手架工程。

背景

react 組件之間會(huì)出現(xiàn)css樣式污染的問題春叫,vue組件之間解決此問題的方式是給<style></style>加上scoped屬性值洼哎,如何處理react樣式污染問題边败?

調(diào)查 (CSS Modules)

CSS模塊就是所有的類名都只有局部作用域的CSS文件业扒。CSS Modules既不是官方標(biāo)準(zhǔn)减途,也不是瀏覽器的特性酣藻,而是在構(gòu)建步驟(例如使用Webpack或Browserify)中對(duì)CSS類名選擇器限定作用域的一種方式(通過hash實(shí)現(xiàn)類似于命名空間的方法)。
原理:在使用CSS模塊時(shí)鳍置,類名是動(dòng)態(tài)生成的辽剧,唯一的,并準(zhǔn)確對(duì)應(yīng)到源文件中的各個(gè)類的樣式税产。

用法

第一種用法:

編寫一個(gè) css 文件:Button.module.css (關(guān)鍵在于xxx.module.css格式)

.error {
    background-color: red;
}

組件引用

import React, { Component } from 'react';
import styles from './Button.module.css'; // 使用 CSS Modules 的方式引入

class Button extends Component {
  render() {
    // 使用方式為模塊名.類名
    return <button className={styles.error}>Error Button</button>;
  }
}

第二種用法:
1.在命令行運(yùn)行 npm run eject 命令
2.運(yùn)行完成之后怕轿,打開 config 目錄下的 webpack.config.js 文件偷崩,找到 test: cssRegex 這一行
3.在 use 屬性執(zhí)行的方法中添加 modules: true,如下圖:


image

4.react組件中的使用和第一個(gè)方式相同撞羽。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末阐斜,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子放吩,更是在濱河造成了極大的恐慌智听,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,496評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件渡紫,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡考赛,警方通過查閱死者的電腦和手機(jī)惕澎,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,407評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來颜骤,“玉大人唧喉,你說我怎么就攤上這事∪坛椋” “怎么了八孝?”我有些...
    開封第一講書人閱讀 162,632評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長鸠项。 經(jīng)常有香客問我干跛,道長,這世上最難降的妖魔是什么祟绊? 我笑而不...
    開封第一講書人閱讀 58,180評(píng)論 1 292
  • 正文 為了忘掉前任楼入,我火速辦了婚禮,結(jié)果婚禮上牧抽,老公的妹妹穿的比我還像新娘嘉熊。我一直安慰自己,他們只是感情好扬舒,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,198評(píng)論 6 388
  • 文/花漫 我一把揭開白布阐肤。 她就那樣靜靜地躺著,像睡著了一般讲坎。 火紅的嫁衣襯著肌膚如雪孕惜。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,165評(píng)論 1 299
  • 那天衣赶,我揣著相機(jī)與錄音诊赊,去河邊找鬼。 笑死府瞄,一個(gè)胖子當(dāng)著我的面吹牛碧磅,可吹牛的內(nèi)容都是我干的碘箍。 我是一名探鬼主播,決...
    沈念sama閱讀 40,052評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼鲸郊,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼丰榴!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起秆撮,我...
    開封第一講書人閱讀 38,910評(píng)論 0 274
  • 序言:老撾萬榮一對(duì)情侶失蹤四濒,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后职辨,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體盗蟆,經(jīng)...
    沈念sama閱讀 45,324評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,542評(píng)論 2 332
  • 正文 我和宋清朗相戀三年舒裤,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了喳资。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,711評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡腾供,死狀恐怖仆邓,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情伴鳖,我是刑警寧澤节值,帶...
    沈念sama閱讀 35,424評(píng)論 5 343
  • 正文 年R本政府宣布,位于F島的核電站榜聂,受9級(jí)特大地震影響搞疗,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜峻汉,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,017評(píng)論 3 326
  • 文/蒙蒙 一贴汪、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧休吠,春花似錦扳埂、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,668評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至柜思,卻和暖如春岩调,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背赡盘。 一陣腳步聲響...
    開封第一講書人閱讀 32,823評(píng)論 1 269
  • 我被黑心中介騙來泰國打工号枕, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人陨享。 一個(gè)月前我還...
    沈念sama閱讀 47,722評(píng)論 2 368
  • 正文 我出身青樓葱淳,卻偏偏與公主長得像钝腺,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子赞厕,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,611評(píng)論 2 353

推薦閱讀更多精彩內(nèi)容

  • 原文地址:react-css-modules閱讀本文前建議了解 CSS Modules 的知識(shí)艳狐。墻裂推薦閱讀 Ca...
    梁相輝閱讀 2,271評(píng)論 1 18
  • CSS Modules 在React中寫樣式有多種方式,比較常見的有 CSS modules,這種方法將css樣式...
    JamesSawyer閱讀 3,888評(píng)論 2 6
  • 1. 新建一個(gè)文件夾,命名為 webpack-cli , webpack-cli 就是你的項(xiàng)目名,項(xiàng)目名建議使用小...
    魯大師666閱讀 1,474評(píng)論 1 3
  • 下載簡(jiǎn)書有半年了皿桑,直到現(xiàn)在毫目,才發(fā)第一篇文。這期間也有陸陸續(xù)續(xù)寫過一些東西诲侮,但最終都無一例外地爛尾镀虐,或是沒有下文。 ...
    iao_q閱讀 183評(píng)論 0 0
  • 今天是我值班,所以6:50近零,我就開始準(zhǔn)備出發(fā)。 因?yàn)榻裉煳业哪赣H要去看望我的姥姥抄肖,我的姥姥住院了久信。所以我想早一點(diǎn),...
    lygly9閱讀 299評(píng)論 0 0