成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

CSS Module

mingzhong / 3345人閱讀

摘要:樣式變多后,命名將更加混亂。缺點是不能利用成熟的預(yù)處理器或后處理器,和偽類處理起來復(fù)雜。經(jīng)過這樣混淆處理后,名基本就是唯一的,大大降低了項目中樣式覆蓋的幾率。就只能使用預(yù)處理器自己的語法來做樣式復(fù)用了。

一 前言

CSS 是前端領(lǐng)域中進化最慢的一塊。由于 ES2015/2016 的快速普及和 Babel/Webpack 等工具的迅猛發(fā)展,CSS 被遠遠甩在了后面,逐漸成為大型項目工程化的痛點。也變成了前端走向徹底模塊化前必須解決的難題。
模塊化解決了JS作用域的問題,但是CSS還是會存在樣式覆蓋的問題,因為最后打包最終會生成一份文件而不是開發(fā)時候的那樣分模塊分作用域。
所以,我們今天討論的是如何在模塊化的工程下放心的寫CSS樣式而不擔心樣式覆蓋,推薦的方案就是CSS Module。

二 正文1.CSS 模塊化遇到了哪些問題

CSS 模塊化重要的是要解決好兩個問題:CSS 樣式的導(dǎo)入和導(dǎo)出。

樣式導(dǎo)入:靈活按需導(dǎo)入以便復(fù)用代碼;

樣式導(dǎo)出:導(dǎo)出時要能夠隱藏內(nèi)部作用域,以免造成全局污染。

Sass/Less/PostCSS 等前仆后繼試圖解決 CSS 編程能力弱的問題,結(jié)果它們做的也確實優(yōu)秀,但這并沒有解決模塊化最重要的問題。Facebook 工程師 Vjeux 首先拋出了 React 開發(fā)中遇到的一系列 CSS 相關(guān)問題。總結(jié)如下:

全局污染

CSS 使用全局選擇器機制來設(shè)置樣式,優(yōu)點是方便重寫樣式。缺點是所有的樣式都是全局生效,樣式可能被錯誤覆蓋,因此產(chǎn)生了非常丑陋的 !important,甚至 inline !important 和復(fù)雜的選擇器權(quán)重計數(shù)表,提高犯錯概率和使用成本。
Web Components 標準中的 Shadow DOM 能徹底解決這個問題,但它的做法有點極端,樣式徹底局部化,造成外部無法重寫樣式,損失了靈活性。

命名混亂

由于全局污染的問題,多人協(xié)同開發(fā)時為了避免樣式?jīng)_突,選擇器越來越復(fù)雜,容易形成不同的命名風(fēng)格,很難統(tǒng)一。樣式變多后,命名將更加混亂。

依賴管理不徹底

組件應(yīng)該相互獨立,引入一個組件時,應(yīng)該只引入它所需要的 CSS 樣式。但現(xiàn)在的做法是除了要引入 JS,還要再引入它的 CSS,而且 Saas/Less 很難實現(xiàn)對每個組件都編譯出多帶帶的 CSS,引入所有模塊的 CSS 又造成浪費。JS 的模塊化已經(jīng)非常成熟,如果能讓 JS 來管理 CSS 依賴是很好的解決辦法。
Webpack 的 css-loader 提供了這種能力。

無法共享變量

復(fù)雜組件要使用 JS 和 CSS 來共同處理樣式,就會造成有些變量在 JS 和 CSS 中冗余,Sass/PostCSS/CSS 等都不提供跨 JS 和 CSS 共享變量這種能力。

代碼壓縮不徹底

由于移動端網(wǎng)絡(luò)的不確定性,現(xiàn)在對 CSS 壓縮已經(jīng)到了{{BANNED}}的程度。很多壓縮工具為了節(jié)省一個字節(jié)會把 "16px" 轉(zhuǎn)成 "1pc"。但對非常長的 class 名卻無能為力,力沒有用到刀刃上。

上面的問題如果只憑 CSS 自身是無法解決的,如果是通過 JS 來管理 CSS 就很好解決,因此 Vjuex 給出的解決方案是完全的 CSS in JS,但這相當于完全拋棄 CSS,在 JS 中以 Object 語法來寫 CSS,估計剛看到的小伙伴都受驚了。直到出現(xiàn)了 CSS Modules。

2.CSS解決方案一覽

CSS 模塊化的解決方案有很多,但主要有兩類:

徹底拋棄 CSS,使用 JS 或 JSON 來寫樣式

Radium,jsxstyle,react-style 屬于這一類。
優(yōu)點是能給 CSS 提供 JS 同樣強大的模塊化能力。
缺點是不能利用成熟的 CSS 預(yù)處理器(或后處理器),Sass/Less/PostCSS,:hover 和 :active 偽類處理起來復(fù)雜。

另一類是依舊使用 CSS,但使用 JS 來管理樣式依賴,

代表是 CSS Modules。
CSS Modules 能最大化地結(jié)合現(xiàn)有 CSS 生態(tài)和 JS 模塊化能力,API 簡潔到幾乎零學(xué)習(xí)成本。
發(fā)布時依舊編譯出多帶帶的 JS 和 CSS。它并不依賴于 React,只要你使用 Webpack,可以在 Vue/Angular/jQuery 中使用。

3.為什么是CSS Module

CSS Modules 能最大化地結(jié)合現(xiàn)有 CSS 生態(tài)和 JS 模塊化能力,API 簡潔到幾乎零學(xué)習(xí)成本。

發(fā)布時依舊編譯出多帶帶的 JS 和 CSS。它并不依賴于 React,只要你使用 Webpack,可以在 Vue/Angular/jQuery 中使用。

4.使用CSS Module

CSS Modules 內(nèi)部通過 ICSS 來解決樣式導(dǎo)入和導(dǎo)出這兩個問題。分別對應(yīng) :import 和 :export 兩個新增的偽類。

:import("path/to/dep.css") {
  localAlias: keyFromDep;
  /* ... */
}
:export {
  exportedKey: exportedValue;
  /* ... */
}

但直接使用這兩個關(guān)鍵字編程太麻煩,實際項目中很少會直接使用它們,我們需要的是用 JS 來管理 CSS 的能力。結(jié)合 Webpack 的 css-loader 后,就可以在 CSS 中定義樣式,在 JS 中導(dǎo)入。

啟用 CSS Modules

// webpack.config.js
css?modules&localIdentName=[name]__[local]-[hash:base64:5]

加上 modules 即為啟用,localIdentName 是設(shè)置生成樣式的命名規(guī)則。
也可以這樣設(shè)置:

         test: /.less$/,
         use: [
                "style-loader",
                {
                    loader: "css-loader",
                    options: {
                        modules: true,
                        localIdentName: "[name]__[local]-[hash:base64:5]",
                    },
                },
               ],
        },

樣式文件Button.css:

.normal { /* normal 相關(guān)的所有樣式 */ }
.disabled { /* disabled 相關(guān)的所有樣式 */ }
/* components/Button.js */
import styles from "./Button.css";

console.log(styles);

buttonElem.outerHTML = ``

生成的 HTML 是

注意到 button--normal-abc53 是 CSS Modules 按照 localIdentName 自動生成的 class 名。其中的 abc53 是按照給定算法生成的序列碼。經(jīng)過這樣混淆處理后,class 名基本就是唯一的,大大降低了項目中樣式覆蓋的幾率。同時在生產(chǎn)環(huán)境下修改規(guī)則,生成更短的class名,可以提高CSS的壓縮率。

上例中 console 打印的結(jié)果是:

Object {
  normal: "button--normal-abc53",
  disabled: "button--disabled-def884",
}

CSS Modules 對 CSS 中的 class 名都做了處理,使用對象來保存原 class 和混淆后 class 的對應(yīng)關(guān)系。

通過這些簡單的處理,CSS Modules 實現(xiàn)了以下幾點:

所有樣式都是 local 的,解決了命名沖突和全局污染問題

class 名生成規(guī)則配置靈活,可以此來壓縮 class 名

只需引用組件的 JS 就能搞定組件所有的 JS 和 CSS

依然是 CSS,幾乎 0 學(xué)習(xí)成本

樣式默認局部
使用了 CSS Modules 后,就相當于給每個 class 名外加加了一個 :local,以此來實現(xiàn)樣式的局部化,如果你想切換到全局模式,使用對應(yīng)的 :global。

.normal {
  color: green;
}

/* 以上與下面等價 */
:local(.normal) {
  color: green; 
}

/* 定義全局樣式 */
:global(.btn) {
  color: red;
}

/* 定義多個全局樣式 */
:global {
  .link {
    color: green;
  }
  .box {
    color: yellow;
  }
}

Compose 來組合樣式
對于樣式復(fù)用,CSS Modules 只提供了唯一的方式來處理:composes 組合

/* components/Button.css */
.base { /* 所有通用的樣式 */ }

.normal {
  composes: base;
  /* normal 其它樣式 */
}

.disabled {
  composes: base;
  /* disabled 其它樣式 */
}

import styles from "./Button.css";

buttonElem.outerHTML = ``

生成的 HTML 變?yōu)?/p>

由于在 .normal 中 composes 了 .base,編譯后會 normal 會變成兩個 class。

composes 還可以組合外部文件中的樣式。

/* settings.css */
.primary-color {
  color: #f40;
}

/* components/Button.css */
.base { /* 所有通用的樣式 */ }

.primary {
  composes: base;
  composes: primary-color from "./settings.css";
  /* primary 其它樣式 */
}

對于大多數(shù)項目,有了 composes 后已經(jīng)不再需要 Sass/Less/PostCSS。但如果你想用的話,由于 composes 不是標準的 CSS 語法,編譯時會報錯。就只能使用預(yù)處理器自己的語法來做樣式復(fù)用了。

class 命名技巧
CSS Modules 的命名規(guī)范是從 BEM 擴展而來。

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/113527.html

相關(guān)文章

  • Vue中scoped csscss module比較

    摘要:官方文檔可以直接在能跑起來的項目中使用。所以在使用的父組件中使用的子組件也要開啟。能正常編譯,而則會編譯的不符合預(yù)期,所以平時養(yǎng)成良好的參數(shù)書寫順序也很重要??偨Y(jié)總結(jié)綜上所述,前期進行不麻煩的配置,實現(xiàn)的效果比更優(yōu),這里推薦使用。scoped css 官方文檔 scoped css可以直接在能跑起來的vue項目中使用。 使用方法: h1 { color: #f00; } 使用scop...

    Faremax 評論0 收藏0
  • react配置less,并使用less module(webpack.config.js配置)

    摘要:網(wǎng)上看了很多配置,最后才發(fā)現(xiàn)后就不用就可以使用特性,那么仿照的配置即可的使用將文件名為配置暴露配置文件安裝依賴修改文件配置,一共修改三處第一處增加定義變量第二處仿照配置第三處修改函數(shù)內(nèi)部,增加圖片描述測試是否安裝成功 網(wǎng)上看了很多配置,最后才發(fā)現(xiàn)create-react-app2.0后就不用eject就可以使用css module特性,那么less仿照css的配置即可 1.css mo...

    imingyu 評論0 收藏0
  • react配置less,并使用less module(webpack.config.js配置)

    摘要:網(wǎng)上看了很多配置,最后才發(fā)現(xiàn)后就不用就可以使用特性,那么仿照的配置即可的使用將文件名為配置暴露配置文件安裝依賴修改文件配置,一共修改三處第一處增加定義變量第二處仿照配置第三處修改函數(shù)內(nèi)部,增加圖片描述測試是否安裝成功 網(wǎng)上看了很多配置,最后才發(fā)現(xiàn)create-react-app2.0后就不用eject就可以使用css module特性,那么less仿照css的配置即可 1.css mo...

    sPeng 評論0 收藏0
  • webpack項目輕松混用css module

    摘要:前言前言本文講述開啟模塊功能之后,如何與引用的包中樣式文件不產(chǎn)生沖突。在不做特殊處理的前提下,樣式文件將會被轉(zhuǎn)譯成。前言 本文講述css-loader開啟css模塊功能之后,如何與引用的npm包中樣式文件不產(chǎn)生沖突。 比如antd-mobilenpm包的引入。在不做特殊處理的前提下,樣式文件將會被轉(zhuǎn)譯成css module。 一、產(chǎn)生問題的原因 { test: /.css$/, ...

    LiuZh 評論0 收藏0
  • 從零開始配置webpack(基于babel 7版本)

    摘要:支持轉(zhuǎn)義轉(zhuǎn)義需要的依賴,支持裝飾器。在中增加的配置數(shù)組中。壓縮文件安裝依賴在中的中增加配置打包前先清空輸出目錄在中增加的配置至此,配置已經(jīng)基本能滿足需求。 webpack 核心概念: Entry: 入口 Module:模塊,webpack中一切皆是模塊 Chunk:代碼庫,一個chunk由十多個模塊組合而成,用于代碼合并與分割 Loader:模塊轉(zhuǎn)換器,用于把模塊原內(nèi)容按照需求轉(zhuǎn)換成...

    waltr 評論0 收藏0
  • 一看就懂之webpack基礎(chǔ)配置

    摘要:一看就懂之基礎(chǔ)配置一簡介本質(zhì)上,是一個現(xiàn)代應(yīng)用程序的靜態(tài)模塊打包器。屬性表示的是的上下文目錄,配置入口文件的時候,如果入口文件使用的是相對路徑,那么就是相對于所在的目錄。通常用于指定以何種方式導(dǎo)出庫,通常用于指定接收庫的名稱。 一看就懂之webpack基礎(chǔ)配置 一、webpack 簡介 本質(zhì)上,webpack 是一個現(xiàn)代 JavaScript 應(yīng)用程序的靜態(tài)模塊打包器(module b...

    woshicixide 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<