原文:.4-淺析webpack源碼之convert-argv模塊

上一節看了一眼預編譯的總體代碼,這一節分析convert argv模塊。 這個模塊主要是對命令參數的解析,也是yargs框架的核心用處。 生成默認配置文件名數組 函數內部,首先判斷了argv.d與argv.p屬性是否存在,這個屬性來源於參數d與p,即webpack d p,測試如圖: 因為懶得加,所以直接跳過,進入到第二階段,生成默認配置文件名數組。 這里引入了一個小的模塊interpret,調 ...

2017-12-12 00:11 1 1491 推薦指數:

查看詳情

.6-淺析webpack源碼之validateSchema模塊

validateSchema模塊   首先來看錯誤檢測:   可以注意到,這里傳了兩個參數,其實第一個參數來源於一個JSON文件:   這個JSON文件非常大,可以觀察一下部分內容:   從描述可以猜測,這里的key對應options中 ...

Thu Dec 14 03:22:00 CST 2017 0 2431
.14-淺析webpack源碼之Watchpack模塊

  解決掉了最頭疼的DirectoryWatcher內部實現,這一節可以結束NodeWatchFileSystem模塊。   關於watch的應用場景,仔細思考了下,這不就是熱重載的核心嘛。   首先是監視文件,觸發文件change事件后收集變動文件信息,重新進行打包,更新JS后觸發頁面重新 ...

Thu Dec 21 05:06:00 CST 2017 1 923
.10-淺析webpack源碼之graceful-fs模塊

  在cachedInput、output、watch三大文件系統中,output非常簡單,沒有必要講,其余兩個模塊依賴於input模塊,而input主要是引用了graceful-fs的部分API,所以這節來講講graceful-fs。   上一節整理的源碼如下:   內容包含 ...

Sat Dec 16 08:24:00 CST 2017 0 2233
.1-淺析webpack源碼webpack.cmd

  此系列隨時可能斷更,畢竟我是解釋型源碼分析……   tips:本系列源碼版本為3.10.0   嘗試看過Spring的源碼,有點燒腦,所以還是重回JS吧!   在配置完環境變量后,可以通過webpack指令進行打包,需要知道的是,如果當前路徑存在webpack ...

Sun Dec 10 22:52:00 CST 2017 8 1987
.15-淺析webpack源碼之WebpackOptionsApply模塊-plugin事件流總覽

  總體過了一下后面的流程,發現Compiler模塊確實不適合單獨講解,這里繼續講解后面的代碼:   這行代碼與之前設置options默認值非常相似,但是復雜程度根本不是一個次元的。   這一節只能簡單的看一眼內部到底有多少東西,整理后源碼如下:   這個模塊 ...

Fri Dec 22 00:05:00 CST 2017 0 979
.3-淺析webpack源碼之預編譯總覽

  寫在前面:   本來一開始想沿用之前vue源碼的標題:webpack源碼之***,但是這個工具比較巨大,所以為防止有人覺得我裝逼跑來噴我(或者隨時鴿),加上淺析二字,以示慫。   既然是淺析,那么案例就不必太復雜,所以繼續按照之前vue源碼,以最簡單形式進行源碼分析,如下:   配置文件 ...

Tue Dec 12 00:14:00 CST 2017 3 1112
.8-淺析webpack源碼之Tapable介紹

Tapable工具      完成webpack默認參數注入后,下一步雖然是 new Compiler() ,但是這東西不是一下可以講完的,復雜的一批。   不如先從工具入手,分塊講解compiler,首先來看看事件流執行器Tapable工具。   tips:這里的Tapable源碼來自於 ...

Thu Dec 14 23:34:00 CST 2017 1 1314
.2-淺析webpack源碼之打包后文件

  先不進源碼,分析一下打包后的文件,來一張圖:      首先創建兩個JS文件,內容如下:   分別為配置文件和入口JS文件,內容弄個簡單的。   接下來在當前目錄執行webpack --config config.js,會輸出一個output.js,簡化后 ...

Mon Dec 11 09:46:00 CST 2017 0 1387
 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM