webPack核心原理一:基本使用

官網(wǎng): https://webpack.js.org/

一句話概括:

webpack是一種前端模塊化的打包工具,它會(huì)從入口文件開(kāi)始粱胜,識(shí)別所有的依賴模塊(js/css/各種其他資源)视译,將其打包成一個(gè)可在瀏覽器端運(yùn)行的可執(zhí)行函數(shù)
當(dāng)然這里的可執(zhí)行函數(shù)的語(yǔ)法需要用babel來(lái)轉(zhuǎn)換
其主要有以下幾種模塊

  • 基本API
  • loaders (因?yàn)閣ebpack只能識(shí)別js/json文件,其他的比如css/圖片等需要通過(guò)加載相對(duì)的loader來(lái)識(shí)別)
  • Plugins (插件在webpack的使用過(guò)程中很重要,webpack的執(zhí)行過(guò)程相當(dāng)于有個(gè)生命周期私沮,插件的目的就是在這個(gè)生命周期過(guò)程中實(shí)現(xiàn)自己需求)
WeChat423e4885bd11e0f5d76b738bf2714c8d.png

簡(jiǎn)單使用

1. 安裝

//安裝webpack V4+版本時(shí),需要額外安裝webpack-cli

npm i webpack -d
npm I -d webpack-cli

//使用npx來(lái)檢測(cè)版本(npx:幫助我們?cè)陧?xiàng)?目中的node_modules里面尋找依賴)
npx webpack -v

2.簡(jiǎn)單構(gòu)建

新建src/index.js和橙、src/index.json仔燕、src/other.js
# index.js
const json = require("./index.json");//commonJS 
import { add } from "./other.js";//es module console.log(json, add(2, 3))
# index.json
{
"name": "JOSN"
}
# other.js
export function add(n1, n2) { return n1 + n2;
}

然后執(zhí)行構(gòu)建,直接會(huì)根據(jù)默認(rèn)的配置 生成可以執(zhí)行運(yùn)行在瀏覽器端的自執(zhí)行函數(shù)

npx webpack

默認(rèn)的配置是:

const path = require("path")
module.exports = {
// 必填 webpack執(zhí)?行行構(gòu)建?入?口 entry: "./src/index.js", output: {
// 將所有依賴的模塊合并輸出到main.js filename: "main.js",
// 輸出?文件的存放路路徑魔招,必須是絕對(duì)路路徑
path: path.resolve(__dirname, "./dist")
} };

然后我們主要的工作是手動(dòng)配置這個(gè)默認(rèn)配置涨享,比如給他加個(gè)loader/plugin等等

3.loader

因?yàn)閣ebpack不認(rèn)識(shí)一些外來(lái)模塊,所以要使用一些加載器仆百,比如識(shí)別css/react/vue/png等

module : {
 rules:[ 
  { test:/\.xxx$/,//指定匹配規(guī)則 
    use:{ loader: 'xxx-load' } //指定使?用的loader
  }厕隧,
...其他的
] }


4. Plugins

plugin 可以在webpack運(yùn)?行行到某個(gè)階段的時(shí)候,幫你做?一些事情俄周,類似于?生 命周期的概念
比如打包的后需要生成一個(gè)html文件吁讨,并且引入生成的bundle.js文件
使用:HtmlWebpackPlugin這個(gè)插件

npm install --save-dev html-webpack-plugin

配置:
這里注意了,插件都是一個(gè)class哦

  plugins:[
    new htmlWebpackPlugin({
    title: "My App",
    filename: "app.html", template: "./src/index.html"
   })
]

編譯后生成

5. 其他配置

  • mode 指定當(dāng)前的構(gòu)建環(huán)境峦朗,使用mode可以觸發(fā)內(nèi)置的函數(shù)建丧,達(dá)到優(yōu)化的效果(比如壓縮)
  • sourceMap 代碼映射關(guān)系 可以較快的找到代碼錯(cuò)誤的地方
devtool:"cheap-module-eval-source-map",// 開(kāi)發(fā)環(huán)境配置
//線上不不推薦開(kāi)啟 
devtool:none
  • WebpackDevServer
    建設(shè)本地跨域代理,配置自刷新瀏覽器
npm install webpack-dev-server -D

修改 package.json
"scripts": {
  "server": "webpack-dev-server"
}

配置:

devServer:{
  open: true,
 port: 8081,
//跨域
  proxy: { "/api": {
    target: "http://localhost:9092" }
}
}

前端請(qǐng)求

axios.get("/api/info").then(res => { console.log(res);

})


最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末波势,一起剝皮案震驚了整個(gè)濱河市翎朱,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌尺铣,老刑警劉巖拴曲,帶你破解...
    沈念sama閱讀 212,332評(píng)論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異凛忿,居然都是意外死亡澈灼,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,508評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門(mén)店溢,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)叁熔,“玉大人,你說(shuō)我怎么就攤上這事床牧∪倩兀” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 157,812評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵戈咳,是天一觀的道長(zhǎng)心软。 經(jīng)常有香客問(wèn)我革砸,道長(zhǎng),這世上最難降的妖魔是什么糯累? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,607評(píng)論 1 284
  • 正文 為了忘掉前任算利,我火速辦了婚禮,結(jié)果婚禮上泳姐,老公的妹妹穿的比我還像新娘效拭。我一直安慰自己,他們只是感情好胖秒,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,728評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布缎患。 她就那樣靜靜地躺著,像睡著了一般阎肝。 火紅的嫁衣襯著肌膚如雪挤渔。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 49,919評(píng)論 1 290
  • 那天风题,我揣著相機(jī)與錄音判导,去河邊找鬼。 笑死沛硅,一個(gè)胖子當(dāng)著我的面吹牛眼刃,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播摇肌,決...
    沈念sama閱讀 39,071評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼擂红,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了围小?” 一聲冷哼從身側(cè)響起昵骤,我...
    開(kāi)封第一講書(shū)人閱讀 37,802評(píng)論 0 268
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎肯适,沒(méi)想到半個(gè)月后变秦,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,256評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡疹娶,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,576評(píng)論 2 327
  • 正文 我和宋清朗相戀三年伴栓,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了伦连。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片雨饺。...
    茶點(diǎn)故事閱讀 38,712評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖惑淳,靈堂內(nèi)的尸體忽然破棺而出额港,到底是詐尸還是另有隱情,我是刑警寧澤歧焦,帶...
    沈念sama閱讀 34,389評(píng)論 4 332
  • 正文 年R本政府宣布移斩,位于F島的核電站肚医,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏向瓷。R本人自食惡果不足惜肠套,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,032評(píng)論 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望猖任。 院中可真熱鬧你稚,春花似錦、人聲如沸朱躺。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,798評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)长搀。三九已至宇弛,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間源请,已是汗流浹背枪芒。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,026評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留谁尸,地道東北人病苗。 一個(gè)月前我還...
    沈念sama閱讀 46,473評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像症汹,于是被迫代替她去往敵國(guó)和親硫朦。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,606評(píng)論 2 350