13、webpack從0到1-css代碼分割

前面chapter11介紹了js的代碼分割,本章說下css的代碼分割如何弄垫释。
git倉庫:webpack-demo

1、開始

  • 前面chapter11章CodeSplitting的時(shí)候已經(jīng)講過代碼分割的概念了撑瞧,是個(gè)什么東西棵譬,但那是對(duì)js模塊做代碼分割,這節(jié)說下css的代碼分割预伺。
  • 主要借助的就是一個(gè)插件:MiniCssExtractPlugin订咸,還是沿用我們以前的代碼,我們先來安裝一下酬诀。
$ cd chapter13
$ npm install mini-css-extract-plugin --save-dev 

2脏嚷、配置

  • 這是一個(gè)插件,并沒有集成到webpack中瞒御,不像前面12章設(shè)置CodeSplitting那樣加個(gè)optimization屬性搞一下就好了父叙,這里我們要走如何使用一個(gè)插件的流程。
  • 進(jìn)入到webpack.config.js中:
    • 首先我們需要在開頭require("mini-css-extract-plugin")引入這個(gè)插件肴裙;
    • 其次我們需要在plugins中使用它趾唱;
    • 然后我們需要把style-loader都替換為這個(gè)插件提供的MiniCssExtractPlugin.loader。(我這里示例只是替換了處理css的践宴,其他less和sass的處理loader一樣也要替換鲸匿,具體看git倉庫源碼吧)
// ...
+ const MiniCssExtractPlugin = require("mini-css-extract-plugin");

module.exports = {
  // ...
  module: {
    rules: [
      // 處理css
      {
        test: /\.css$/,
        use: [
-        "style-loader", 
+        MiniCssExtractPlugin.loader,
         "css-loader", 
         "postcss-loader"
        ]
      },
    ]
  },

  plugins: [
    // 打包前刪除掉dist文件避免文件冗余重復(fù)
    new CleanWebpackPlugin(),
    // 可以為你生成一個(gè)HTML文件
    new HtmlWebpackPlugin({
      title: "webpack從0到1",
      template: "./index.html"
    }),
    // css文件的代碼分割
+   new MiniCssExtractPlugin()
  ]
};
  • 就這樣,基本的css代碼分割就完事了阻肩,雖然比js的代碼分割復(fù)雜一點(diǎn)带欢,但是也還好,接下來就npm run build走一波烤惊。

3乔煞、分析一波

  • 最后,當(dāng)我們打包完成了以后就可以看到dist目錄下多出的css文件了柒室。(分割出來了)


  • 現(xiàn)在整個(gè)dist目錄有點(diǎn)亂了渡贾,我們?cè)诨仡櫜⒄f明介紹一下各個(gè)文件吧。

    • 所有.map文件就不多說了雄右,sourcemap的映射空骚。
    • 首先是0.bundle.js文件,是webpack從0到1-Prefetching/Preloading章的產(chǎn)物擂仍,在示例中因?yàn)槲覀兪褂?code>import()方法動(dòng)態(tài)的加載了footer.js模塊囤屹,所以webpack對(duì)其進(jìn)行了代碼分割。
    • 接下來是vendors~main.bundle.js文件逢渔,因?yàn)樗彩莣ebpack對(duì)其代碼分割生成生的肋坚,是webpack從0到1-CodeSplitting代碼分割章節(jié)的產(chǎn)物,里面是axios的js代碼,為什么與0.bundle.js沒有合并到一起呢智厌?因?yàn)?code>axios的引入是在node_modules里面的诲泌,它們的引入方式對(duì)應(yīng)兩個(gè)不同的緩存組,所以分割為了兩個(gè)文件铣鹏。
    • index.htmlHtmlWebpackPlugin這個(gè)插件做的好事羅敷扫。
    • main.bundle.js就是webpack中定義的output指定輸出文件了。
    • main.css就是我們這章說的css代碼分割的產(chǎn)物了吝沫。

4呻澜、小結(jié)

  • 內(nèi)容就這么多,官網(wǎng)還是要看一看惨险。
    參考鏈接
  • MiniCssExtractPlugin
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末羹幸,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子辫愉,更是在濱河造成了極大的恐慌栅受,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,194評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件恭朗,死亡現(xiàn)場(chǎng)離奇詭異屏镊,居然都是意外死亡痰腮,警方通過查閱死者的電腦和手機(jī)而芥,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,058評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來膀值,“玉大人,你說我怎么就攤上這事歌逢≮甯撸” “怎么了?”我有些...
    開封第一講書人閱讀 156,780評(píng)論 0 346
  • 文/不壞的土叔 我叫張陵处面,是天一觀的道長魂角。 經(jīng)常有香客問我,道長智绸,這世上最難降的妖魔是什么野揪? 我笑而不...
    開封第一講書人閱讀 56,388評(píng)論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮瞧栗,結(jié)果婚禮上斯稳,老公的妹妹穿的比我還像新娘。我一直安慰自己迹恐,他們只是感情好挣惰,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,430評(píng)論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著殴边,像睡著了一般憎茂。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上锤岸,一...
    開封第一講書人閱讀 49,764評(píng)論 1 290
  • 那天竖幔,我揣著相機(jī)與錄音,去河邊找鬼是偷。 笑死拳氢,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的晓猛。 我是一名探鬼主播饿幅,決...
    沈念sama閱讀 38,907評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼戒职!你這毒婦竟也來了栗恩?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,679評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤洪燥,失蹤者是張志新(化名)和其女友劉穎磕秤,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體捧韵,經(jīng)...
    沈念sama閱讀 44,122評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡市咆,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,459評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了再来。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片蒙兰。...
    茶點(diǎn)故事閱讀 38,605評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡磷瘤,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出搜变,到底是詐尸還是另有隱情采缚,我是刑警寧澤,帶...
    沈念sama閱讀 34,270評(píng)論 4 329
  • 正文 年R本政府宣布挠他,位于F島的核電站扳抽,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏殖侵。R本人自食惡果不足惜贸呢,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,867評(píng)論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望拢军。 院中可真熱鬧楞陷,春花似錦、人聲如沸茉唉。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,734評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽赌渣。三九已至魏铅,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間坚芜,已是汗流浹背览芳。 一陣腳步聲響...
    開封第一講書人閱讀 31,961評(píng)論 1 265
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留鸿竖,地道東北人沧竟。 一個(gè)月前我還...
    沈念sama閱讀 46,297評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像缚忧,于是被迫代替她去往敵國和親悟泵。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,472評(píng)論 2 348

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

  • 一闪水、入坑初探 1. 設(shè)置項(xiàng)目為私有 我們只需要在package.json文件中配置糕非,因?yàn)槭撬接许?xiàng)目不需要向外部暴露...
    zxhnext閱讀 2,033評(píng)論 0 15
  • 初始化項(xiàng)目 進(jìn)入一個(gè)文件夾作為項(xiàng)目的根目錄 npm init 新建src, dist目錄,package.json...
    love_program閱讀 1,234評(píng)論 0 4
  • 記得2004年的時(shí)候球榆,互聯(lián)網(wǎng)開發(fā)就是做網(wǎng)頁朽肥,那時(shí)也沒有前端和后端的區(qū)分,有時(shí)一個(gè)網(wǎng)站就是一些純靜態(tài)的html持钉,通過...
    陽陽陽一堆陽閱讀 3,275評(píng)論 0 5
  • 構(gòu)建工具逐漸成為前端工程必備的工具衡招,Grunt、Gulp每强、Fis始腾、Webpack等等州刽,譯者有幸使用過Fis、Gul...
    陳堅(jiān)生閱讀 5,997評(píng)論 4 64
  • 01 勸慰自己 上個(gè)月臨去北京考博前浪箭,領(lǐng)了同志們666的紅包怀伦,滿懷忐忑之情去帝都自己夢(mèng)寐以求的高等學(xué)府參加考試。經(jīng)...
    留住小時(shí)光閱讀 236評(píng)論 2 0