摘要:這是局部安裝局部安裝的使用要帶路徑哇,要寫路徑,好麻煩哦,沒事,那就全局安裝吧。如果該值是一個相對路徑,它將相對于包含的文件。就相當于就相當于就相當于后面帶有意味著要完全匹配如果,因為沒完全匹配,那么加載的是下文件夾里的使用教程二
Webpack是什么,我就不過多介紹了,大家都有耳聞,不過還是配張圖讓大家體會下。
我的webpack版本是 3.10.0
安裝Webpack可以全局安裝和局部安裝。局部安裝的話就最好在安裝的當前目錄下運行,你硬要在在外部用webpack?那你在命令行要輸入安裝webpack位置的路徑了。
npm install --save webpack // 這是局部安裝 ./node_modules/.bin/webpack --help // 局部安裝的使用要帶路徑
哇,要寫路徑,好麻煩哦,沒事,那就全局安裝吧。
npm install -g webpack
現(xiàn)在用webpack一般都寫好配置文件的了,webpack.config.js,那么接下來就說這個配置文件主要怎樣寫。
module.exports = { devtool: "#eval-source-map", // 這個是打包的方式 entry: "./main.js", // 入口文件。支持數(shù)組形式,將加載數(shù)組中的所有模塊,但以最后一個模塊作為輸出,對象形式也一樣。 output: { path: "./js", // 打包后的文件存放位置 publicPath: "/dist/", // 這個下面詳說 filename: "build.js" // 打包后的文件名 }, resolve: { // 查找module的話從這里開始查找,下面詳說。 root: "D:/webpack-test/src", extensions: [".js", ".json", ".scss"], alias: { // 下面有例子。 } } };devtool:打包方式。(官網(wǎng)的文檔)
devtool選項 | 打包速度 | 重建速度 | 是否支持生產(chǎn)模式 |
---|---|---|---|
source-map | - | - | 支持 |
eval-source-map | - | + | 不支持 |
cheap-module-source-map | 0 | - | 支持 |
cheap-module-eval-source-map | 0 | ++ | 不支持 |
cheap-source-map | + | 0 | 支持 |
cheap-eval-source-map | + | ++ | 不支持 |
eval | +++ | +++ | 不支持 |
從上到下,打包速度越來越快,開發(fā)環(huán)境一般用eval-source-map,生產(chǎn)環(huán)境自行斟酌咯。畢竟打包越快,打包質(zhì)量也就越差。還有,不知大家發(fā)現(xiàn)沒,帶eval都不支持生產(chǎn)模式哦。
publicPath (官網(wǎng)的文檔)它被用來更新內(nèi)嵌到css、html文件里的url值。
上面 publicPath: "/dist/" ,例如:
background-image:url("./test.png) // 路徑變?yōu)?/dist/.test.png" path: "/js" // 上面打包后的文件位置,那么路徑變?yōu)?/dist/js/build.js"
pubilcPath很重要。在生產(chǎn)模式下如“test.png”文件可能會定位到CDN上并且你的Node.js服務(wù)器可能是運行在HeroKu(一個支持多種編程語言的云平臺)上邊的。一張圖片,手動修改下咯,那如果你網(wǎng)站有上百張呢,那publicPath:"你服務(wù)器的ip地址",這樣省事很多吧。
resolve (官網(wǎng)的文檔)root:包含您的模塊的目錄(絕對路徑)。
extensions: 加載模塊時可忽略的擴展名。
alias:模塊別名定義。舉些例子:
"Abc": "/js/x/y/z/abc.js" // require("Abc"); 相當于 require("/js/x/y/z/abc.js") // 如果 require("Abc/index.js"), 這樣不行的。 "Abc": "./js/x/y/z/abc.js" // 如果該值是一個相對路徑,它將相對于包含require的文件。 // 例如:在test.js中require("Abc"), 那么test.js和abc.js要在同目錄下的。 "Abc": "/js/store" // require("Abc") 就相當于 require("/js/store/index.js") // require("Abc/other.js") 就相當于 require("/js/store/other.js") "Abc$": "/js/store" // require("Abc") 就相當于 require("/js/store/index.js") // 后面帶有 $ ,意味著要完全匹配 "Abc" // 如果 require("Abc/other.js"),因為沒完全匹配Abc,那么加載的是 node_modules下Abc文件夾里的other.js?。?!使用教程(二)--- module.loaders
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/90279.html
摘要:使用教程一,,,使用教程二使用教程三我的版本是官方的文檔在開發(fā)模式下,提供虛擬服務(wù)器,讓我們進行開發(fā)和調(diào)試。文檔如果為,開啟虛擬服務(wù)器時,為你的代碼進行壓縮。的警告和錯誤是不輸出到終端的。而則作用于請求路徑上的。不想啟用也可以填。 使用教程(一)--- entry,devtool,output,resolve使用教程(二)--- module.loaders使用教程(三)--- pl...
摘要:剛寫的時候,心里有很多小聲音寫不好的萬一寫錯,誤導別人怎么辦等等。最重要還是感謝你的支持。接下來還會寫些有趣的東西帶給大家。 這個教程就此完結(jié)咯,兩周前的一個念頭也實現(xiàn)了。剛寫的時候,心里有很多小聲音: 寫不好的 , 萬一寫錯,誤導別人怎么辦 等等。萬事開頭難,寫著寫著就發(fā)現(xiàn)和之前看到的一句話很貼切,輸入一些東西很簡單的,但你要輸出確實比較難 。 使用教程(一)--- entry,...
摘要:使用教程一,,,使用教程二版本官方的文檔上一篇講到的是被用來轉(zhuǎn)換某些類型的模塊,它則可以用來做更廣泛的任務(wù)??煽醋鹘壎ㄊ录虬鼤r會觸發(fā)事件。它的作用是定義全局常量,是常量。為,啟用兩步之間的延遲。請注意,規(guī)范建議始終使用引號。 使用教程(一)--- entry,devtool,output,resolve使用教程(二)--- module.loadersWebpack版本 3.10...
摘要:發(fā)覺其實真的不難,畢竟它是一個工具,如果用起來都不順手,那為什么那么多人用,是不是。我覺得可以把當成人物養(yǎng)成游戲來玩,哦不,來學。聽說把寶石放進這工具就能自動更新打包。公司最近弄來了一些未來的文言文,你把它翻譯成現(xiàn)代文吧。 前言 這段可以跳過看下面的。 本來,這個教程想完結(jié)的了。但回頭看自己寫的,感覺就像寫明了什么意思,具體怎么使用都沒說明白,而且讓人看得會有點乏味吧。 我也是剛開始...
摘要:官方的文檔模塊受到影響的選項。官方文檔通過注入標簽將添加到。官方文檔這兩者一般都是配合在一起用的。代表圖片打包限制,這個限制并不是說超過了就不能打包,而是指當圖片大小小于限制時會自動轉(zhuǎn)成碼引用。不過它的放后面。 第一篇講了Webpack的安裝,以及配置文件的 entry,devtool,output,resolve。這篇接著說配置文件的 module。想看看第一篇的朋友可以點 這里。 ...
閱讀 3753·2021-10-13 09:39
閱讀 3804·2021-09-24 09:48
閱讀 1203·2021-09-01 10:30
閱讀 2533·2019-08-30 15:55
閱讀 1786·2019-08-29 16:39
閱讀 2304·2019-08-26 13:55
閱讀 3057·2019-08-26 12:23
閱讀 1643·2019-08-26 11:59