webpack 入門(一):webpack安裝和基礎(chǔ)項(xiàng)目配置

一妈倔、webpack簡介

1. webpack是什么:

webpack是一個(gè)打包工具:本質(zhì)上webpack 是一個(gè)現(xiàn)代 JavaScript 應(yīng)用程序的靜態(tài)模塊打包器(module bundler)锁摔。
當(dāng) webpack 處理應(yīng)用程序時(shí)损离,它會遞歸地構(gòu)建一個(gè)依賴關(guān)系圖(dependency graph),其中包含應(yīng)用程序需要的每個(gè)模塊禁谦,然后將所有這些模塊打包成一個(gè)或多個(gè) bundle胁黑。

2. webpack的作用:

(1)打包:把多個(gè)文件打包成一個(gè)js文件,以減少服務(wù)器壓力和貸款州泊。
(2)轉(zhuǎn)化:使用loader轉(zhuǎn)化lees丧蘸、sass、ts等拥诡。
(3)優(yōu)化:SPA項(xiàng)目越來越盛行触趴,前端項(xiàng)目復(fù)雜度高,webpack可以對項(xiàng)目進(jìn)行優(yōu)化渴肉。

3. webpack構(gòu)成:

(1)入口:entry
(2)出口:output
(3)loader:轉(zhuǎn)化器
(4)plugins:插件
(5)devServer:開發(fā)服務(wù)器
(6)mode

4. webpack的兩種環(huán)境

(1)開發(fā)環(huán)境(development):就是你平常寫代碼的環(huán)境冗懦。
(2)生產(chǎn)環(huán)境(production):項(xiàng)目開發(fā)完畢,部署上線仇祭。

二披蕉、webpack安裝和基礎(chǔ)項(xiàng)目配置

1.創(chuàng)建項(xiàng)目文件夾(webpack-demo),并建立基礎(chǔ)的目錄和結(jié)構(gòu)

pwebpack
  dist                          //靜態(tài)文件存放的文件夾(distribution)
    index.html                 //最終要瀏覽的html文件
  src                            //js代碼等存放的文件夾(source)
    index.js                  //js代碼主文件
  webpack.config.js         //webpack配置文件
  1. 編寫index.html和index.js文件
//index.html
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>hello webpack</title>
</head>
<body>
    <script src="./bundle.js"></script>    //bundle.js文件我們后面會通過打包創(chuàng)建
</body>
</html>
//index.js
document.write('hello webpack i am  so happy!);
  1. 編寫webpack.config.js文件
//webpack.config.js
const path = require('path');      //引入path乌奇,以處理路徑問題
console.log(path.resolve(__dirname,'src/index.js'));   //打印路徑没讲,以排查錯(cuò)誤(非必要代碼)
module.exports = {
    //入口配置
    entry: {
        main: path.resolve(__dirname,'src/index.js'),
    },
    //出口配置
    output: {
        path: path.resolve(__dirname,'dist'),         //此處若非絕對路徑,可能報(bào)錯(cuò)
        filename: 'bundle.js',
    },
    //以下可按需配置
    //module rules loaders
    module: {},
    //插件
    plugins: [],
    //開發(fā)服務(wù)器
    devServer: {},
};
  1. 命令行進(jìn)入項(xiàng)目并全局安裝webpack(必須已安裝node)
...\webpack>cnpm install webpack-cli -g         //參數(shù)-g為全局安裝`
  1. 項(xiàng)目初始化(即自動建立項(xiàng)目依賴配置文件:package.json)
...\webpack>cnpm init -y               //參數(shù)-y可以跳過初始化中的配置詢問礁苗。
  1. 命令行安裝項(xiàng)目本地依賴webpack爬凑、webpack-lic(必須已安裝node)
...\webpack>cnpm i webpack webpack-cli -D    //參數(shù)-D為--save-dev簡寫`

*注意:此命令會自動生成node_modules文件夾存放項(xiàng)目本地依賴,同時(shí)原有package.json文件中會新增"devDependencies"對象用于記錄本地安裝的依賴试伙, 當(dāng)項(xiàng)目本地依賴被刪除時(shí)嘁信,運(yùn)行cnpm install -D即可根據(jù)package.json中的記錄自動安裝項(xiàng)目本地依賴,這非常重要疏叨!

  1. 打包文件潘靖,生成出口文件bundle.js
...\webpack>webpack --mode development    //--mode devlopment設(shè)置為開發(fā)模式,否則會有設(shè)置模式的警告
  1. 在瀏覽器中打開index.html即可瀏覽蚤蔓,至此簡單的webpack打包就成功了卦溢。

三、其它事項(xiàng)

  1. 遇到的問題:
    P阌帧5ゼ拧!注意如果修改了package.json打包可能會報(bào)錯(cuò):
    ERROR in Entry module not found: SyntaxError: E:\webpack-demo\package.json (directory description file)
    將package.json刪除涮坐,重新初始化文件凄贩,這時(shí)再重新打包則成功了。
  2. 通過配置package.json中的 "scripts"袱讹,可以新增命令疲扎。
    在package.json文件的"scripts"中新增build:
"scripts": {
    "test": "echo \"Error: no test specified\" && exit 1",
    "build": "webpack --config webpack.config.js --mode development"       
  },

保存后,直接運(yùn)行...\webpack>cnpm run build即可打包捷雕。
=飞ァ!救巷!注意如果新增build時(shí)缺少--config webpack.config.js部分則可能報(bào)錯(cuò)壶熏。

  1. webpack.config.js為webpack配置文件的默認(rèn)名稱,不建議修改浦译,但是可以修改棒假。
    如果將webpack配置文件名稱修改為haha.config.js溯职,則打包時(shí)需運(yùn)行
    ...\webpack>webpack --config haha.config.js
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市帽哑,隨后出現(xiàn)的幾起案子谜酒,更是在濱河造成了極大的恐慌,老刑警劉巖妻枕,帶你破解...
    沈念sama閱讀 212,718評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件僻族,死亡現(xiàn)場離奇詭異,居然都是意外死亡屡谐,警方通過查閱死者的電腦和手機(jī)述么,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,683評論 3 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來愕掏,“玉大人度秘,你說我怎么就攤上這事⊥ふ洌” “怎么了敷钾?”我有些...
    開封第一講書人閱讀 158,207評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長肄梨。 經(jīng)常有香客問我阻荒,道長,這世上最難降的妖魔是什么众羡? 我笑而不...
    開封第一講書人閱讀 56,755評論 1 284
  • 正文 為了忘掉前任侨赡,我火速辦了婚禮,結(jié)果婚禮上粱侣,老公的妹妹穿的比我還像新娘羊壹。我一直安慰自己,他們只是感情好齐婴,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,862評論 6 386
  • 文/花漫 我一把揭開白布油猫。 她就那樣靜靜地躺著,像睡著了一般柠偶。 火紅的嫁衣襯著肌膚如雪情妖。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 50,050評論 1 291
  • 那天诱担,我揣著相機(jī)與錄音毡证,去河邊找鬼。 笑死蔫仙,一個(gè)胖子當(dāng)著我的面吹牛料睛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 39,136評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼恤煞,長吁一口氣:“原來是場噩夢啊……” “哼屎勘!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起居扒,我...
    開封第一講書人閱讀 37,882評論 0 268
  • 序言:老撾萬榮一對情侶失蹤挑秉,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后苔货,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,330評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡立哑,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,651評論 2 327
  • 正文 我和宋清朗相戀三年夜惭,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片铛绰。...
    茶點(diǎn)故事閱讀 38,789評論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡诈茧,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出捂掰,到底是詐尸還是另有隱情敢会,我是刑警寧澤,帶...
    沈念sama閱讀 34,477評論 4 333
  • 正文 年R本政府宣布这嚣,位于F島的核電站鸥昏,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏姐帚。R本人自食惡果不足惜吏垮,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,135評論 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望罐旗。 院中可真熱鬧膳汪,春花似錦、人聲如沸九秀。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,864評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽鼓蜒。三九已至痹换,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間友酱,已是汗流浹背晴音。 一陣腳步聲響...
    開封第一講書人閱讀 32,099評論 1 267
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留缔杉,地道東北人锤躁。 一個(gè)月前我還...
    沈念sama閱讀 46,598評論 2 362
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親系羞。 傳聞我的和親對象是個(gè)殘疾皇子郭计,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,697評論 2 351

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