Webpack 指南(上)

一. 起步

1. 使用配置文件

  • 目錄結(jié)構(gòu)
|- /dist
   |- index.html
|- /src
   |- index.js
|- webpack.config.js
  • webpack.config.js
const path = require('path');

module.exports = {
  entry: './src/index.js',
  output: {
    filename: 'bundle.js',
    path: path.resolve(__dirname, 'dist');
  },
};

2. 使用 NPM Scripts

{
  "scripts": {
    "build": "webpack --config webpack.config.js"
   },
}

二. 管理資源

  • 為了使 webpack 能夠打包處理除了 JavaScript 的其他類型文件(.css, .jpg, .ts, ...),需要使用 Loader 來做中間處理
  • 首先應(yīng)當先安裝對應(yīng)的 Loader
// 處理 CSS
npm install --save-dev style-loader css-loader
// 處理圖片(png|svg|jpg|gif)
npm install --save-dev file-loader
  • 對 webpack.config.js 的相應(yīng)配置
module: {
  rules: [{
    test: /\.css$/,
    use: ['style-loader', 'css-loader'],
  }],
},
  • webpack 會分析文件的類型并用正則去匹配确徙,找到對應(yīng)的配置,并使用指定的一個或多個 Loader 進行流式解析
  • 在適當?shù)那闆r下,可以將模塊與資源分離到同一目錄中并進行封裝隅肥,在某些場合下颊亮,這樣使你的組件/模塊更具備可移植性,統(tǒng)一的放置資源會造成強烈的耦合,然而并沒有一成不變的配置方式,最好的永遠是最適合自己項目應(yīng)用場景的

三. 管理輸出

  • 當輸出文件涉及到 hash 文件名時,沒辦法在根 index.html 中固定的指定 src椎木,然而可以使用 HtmlWebpackPlugin 來解決這個問題
  • 當使用自動的生成構(gòu)建時,目標文件夾可能存在曾經(jīng)的遺留文件博烂,因為文件的名稱存在 hash香椎,所以并不會替代掉舊的文件,可以使用 CleanWebpackPlugin 插件來清空 dist 文件夾
const path = require('path');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const CleanWebpackPlugin = require('clean-webpack-plugin');

module.exports = {
  entry: './src/index.js',
  output: {
    filename: '[name].[hash:8].js',
    path: path.resolve(__dirname, 'dist'),
  },
  plugins: [
    new CleanWebpackPlugin(['dist']),
    new HtmlWebpackPlugin({ title: 'Hello Webpack!' }),
  ],
};

四. 開發(fā)

1. 使用 Source Map

// webpack.config.js
devtool: 'inline-source-map',

2. 使用 webpack-dev-server

  • 需要安裝 webpack-dev-server 插件
npm install webpack-dev-server --save-dev
  • 配置 webpack.config.jslocalhost:8080 下建立服務(wù)禽篱,并將 dist 目錄下的文件畜伐,作為可訪問文件
devServer: {
  contentBase: './dist',
},
  • 使用 webpack-dev-server --open 命令運行開發(fā)服務(wù)器

3. 使用 webpack-dev-middleware

  • webpack-dev-middle 將 webpack 處理的文件發(fā)送到服務(wù)器的包裝器,它在 webpack-dev-server 內(nèi)部使用躺率,但它可以作為單獨的包引用玛界,以允許更多的自定義設(shè)置,通常將其和服務(wù)器相結(jié)合來使用
  • 首先安裝 express 和 webpack-dev-middleware
npm install express webpack-dev-middleware --save-dev
  • 修改 webpack.config.js 的 publicPath
output: {
  //...
  publicPath: '/',
},
  • 創(chuàng)建 server.js
const express = require('express');
const webpack = require('webpack');
const webpackDevMiddleware = require('webpack-dev-middleware');

const app = express();
const config = require('./webpack.config.js');
const compiler = webpack(config);

app.use(webpackDevMiddleware(compiler, {
  publicPath: config.output.publicPath
}));

app.listen(3000);
  • 使用 node server.js 來運行服務(wù)器悼吱,啟動瀏覽器并進入 http://localhost:3000 來訪問慎框,當源碼的內(nèi)容發(fā)生變化時,webpack-dev-middleware 會檢測到變化并將其在內(nèi)存中寫入更新后添,但這并不會導(dǎo)致瀏覽器的自動刷新笨枯,必須手動刷新才會讓瀏覽器感受到本次的變化,而并不需要重新啟動服務(wù)器

4. 使用 HMR

  • 修改 webpack.config.js
const webpack = require('webpack');

devServer: {
  contentBase: './dist',
  hot: true,
},

plugins: [new webpack.HotModuleReplacementPlugin()],
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末遇西,一起剝皮案震驚了整個濱河市馅精,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌粱檀,老刑警劉巖洲敢,帶你破解...
    沈念sama閱讀 206,482評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異茄蚯,居然都是意外死亡沦疾,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,377評論 2 382
  • 文/潘曉璐 我一進店門第队,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人刨秆,你說我怎么就攤上這事凳谦。” “怎么了衡未?”我有些...
    開封第一講書人閱讀 152,762評論 0 342
  • 文/不壞的土叔 我叫張陵尸执,是天一觀的道長家凯。 經(jīng)常有香客問我,道長如失,這世上最難降的妖魔是什么绊诲? 我笑而不...
    開封第一講書人閱讀 55,273評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮褪贵,結(jié)果婚禮上掂之,老公的妹妹穿的比我還像新娘。我一直安慰自己脆丁,他們只是感情好世舰,可當我...
    茶點故事閱讀 64,289評論 5 373
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著槽卫,像睡著了一般跟压。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上歼培,一...
    開封第一講書人閱讀 49,046評論 1 285
  • 那天震蒋,我揣著相機與錄音,去河邊找鬼躲庄。 笑死查剖,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的读跷。 我是一名探鬼主播梗搅,決...
    沈念sama閱讀 38,351評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼效览!你這毒婦竟也來了无切?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 36,988評論 0 259
  • 序言:老撾萬榮一對情侶失蹤丐枉,失蹤者是張志新(化名)和其女友劉穎哆键,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體瘦锹,經(jīng)...
    沈念sama閱讀 43,476評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡籍嘹,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,948評論 2 324
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了弯院。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片辱士。...
    茶點故事閱讀 38,064評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖听绳,靈堂內(nèi)的尸體忽然破棺而出颂碘,到底是詐尸還是另有隱情,我是刑警寧澤椅挣,帶...
    沈念sama閱讀 33,712評論 4 323
  • 正文 年R本政府宣布头岔,位于F島的核電站塔拳,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏峡竣。R本人自食惡果不足惜靠抑,卻給世界環(huán)境...
    茶點故事閱讀 39,261評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望适掰。 院中可真熱鬧颂碧,春花似錦、人聲如沸攻谁。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,264評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽戚宦。三九已至个曙,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間受楼,已是汗流浹背垦搬。 一陣腳步聲響...
    開封第一講書人閱讀 31,486評論 1 262
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留艳汽,地道東北人猴贰。 一個月前我還...
    沈念sama閱讀 45,511評論 2 354
  • 正文 我出身青樓,卻偏偏與公主長得像河狐,于是被迫代替她去往敵國和親米绕。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 42,802評論 2 345

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

  • 無意中看到zhangwnag大佬分享的webpack教程感覺受益匪淺馋艺,特此分享以備自己日后查看栅干,也希望更多的人看到...
    小小字符閱讀 8,140評論 7 35
  • 構(gòu)建一個小項目——FlyBird,學習webpack和react捐祠。(本文成文于2017/2/25) 從webpac...
    布蕾布蕾閱讀 16,801評論 31 98
  • GitChat技術(shù)雜談 前言 本文較長碱鳞,為了節(jié)省你的閱讀時間,在文前列寫作思路如下: 什么是 webpack踱蛀,它要...
    蕭玄辭閱讀 12,674評論 7 110
  • 在現(xiàn)在的前端開發(fā)中窿给,前后端分離、模塊化開發(fā)率拒、版本控制崩泡、文件合并與壓縮、mock數(shù)據(jù)等等一些原本后端的思想開始...
    Charlot閱讀 5,431評論 1 32
  • Implement Reinforcement learning, finish the learning vid...
    Fernando23閱讀 255評論 0 1