亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

webpack4之如何編寫loader的方法步驟

2019-11-19 11:23:10
字體:
來源:轉載
供稿:網友

之前學習過webpack3的知識,但是webpack4升級后還是有很多變動的,所以這次重新整理一下webpack4的知識點,方便以后復習。

這次學習webpack4不僅僅要會配置,記住核心API,最好還要理解一下webpack更深層次的知識,比如打包原理等等,所以可能會省略一些比較基礎的內容,但是希望我可以通過此次學習掌握webpack,更好地應對以后的工作。

1.編寫入門級loader

我在之前的文章中,已經把webpack基礎的內容基本上都過了一遍,現在開始準備復習更高級的webpack知識了,首先從loader開始。

首先初始化一個項目

npm init

然后安裝依賴

cnpm install -D webpack webpack-cli

創建一個src目錄,里面創建一個index.js

新建一個webpack.config.js,寫入最基本的配置

如果此時,我們有個需求,中打包過程中,需要把world替換成mark,我們就可以借助loader來實現。首先在src同級目錄新建一個loader文件夾,里面新建一個replaceLoader.js。

replaceLoader.js需要導出一個函數,注意:這個函數不能是箭頭函數,因為webpack調用loader的時候會對this做一些變更,上面有一些方法,如果使用箭頭函數,this指向就會有問題,沒有辦法調用this上的一些方法。

函數可以接受一個參數,參數是我們源代碼的內容,所以可以對source進行操作后,return source,就可以改變源代碼了。

然后使用我們自己寫的loader,use就不填寫loader名稱了,需要寫我們編寫的loader的路徑。

這樣我們打包后發現,world已經被替換成mark了,這樣我們就實現了一個最簡單的loader。

2.給loader配置參數

loader中常??梢耘渲靡恍﹨?,那么我們如果想配置參數,要怎么做呢?

此時在replaceLoader中,可以通過this.query訪問到參數。

這樣打包后,結果就會替換成我們的參數,但是官方推薦我們使用loader-utils來傳參。

cnpm install --save-dev loader-utils

這樣打包的結果也是我們傳入的參數。

3.this.callback

有時候我們不止要return一個resource,還可能要返回多個結果,就需要用到callback。

this.callback( err: Error | null, content: string | Buffer, sourceMap?: SourceMap, meta?: any);

第一個參數是錯誤,第二個是結果,第三個是sourcemap,第四個可以是任何內容(比如元數據)

4. this.async

在loader中,如果我們直接調用setTimeout,就會報錯,那么如果我們想進行異步操作要怎么做呢?

當要使用異步的時候,需要先把callback變為this.callback,然后再返回結果(和this.callback一樣)。

這樣再打包就不會有任何問題。

額外知識點:我們現在配置loader的時候,需要使用path.resolve,有沒有什么方法可以像其他loader一樣引用呢?

這樣只寫loader名稱,webpack就會先到node_modules里面找,找不到就去當前目錄下的loaders中去找。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩福利视频在线观看| 欧美特级www| 欧美激情视频一区二区| 欧美日韩国产综合新一区| 国产mv免费观看入口亚洲| 国产成人免费av电影| 亚洲片在线观看| 欧美高跟鞋交xxxxhd| 久久av中文字幕| 亚洲欧美国产视频| 久久久久久久久久久成人| 亚洲欧美中文在线视频| 国产欧美日韩91| 中文字幕亚洲欧美| 欧美一级大片视频| 成人网在线视频| 欧美成人黑人xx视频免费观看| 久久久久久成人| 日韩av在线导航| 亚洲欧美成人一区二区在线电影| 国产成人久久久| 美女扒开尿口让男人操亚洲视频网站| 国产精品欧美一区二区三区奶水| 尤物九九久久国产精品的分类| 国产视频欧美视频| 一区二区三区无码高清视频| 97视频在线观看视频免费视频| 日韩免费精品视频| 亚洲人成网站免费播放| 97国产suv精品一区二区62| 欧美在线视频观看免费网站| 97国产一区二区精品久久呦| 国产精品91久久久| 亚洲国产成人在线视频| 久久久久久久久中文字幕| 亚洲免费影视第一页| 黄色成人在线播放| 日韩亚洲国产中文字幕| 久久久999国产精品| 亚洲性生活视频| 日韩高清有码在线| 亚洲性夜色噜噜噜7777| 福利视频一区二区| 亚洲精品狠狠操| 亚洲精品视频在线播放| 国产精品亚洲片夜色在线| 久久久亚洲国产| 亚洲最新视频在线| 亚洲第一区在线观看| 色www亚洲国产张柏芝| 久久久精品久久久久| 国产精品最新在线观看| 国产精品一区二区三区在线播放| 欧美www在线| 久久久精品一区二区| 一区二区三区回区在观看免费视频| 777午夜精品福利在线观看| 成人免费视频xnxx.com| 欧美精品午夜视频| 97人人做人人爱| 亚洲欧美中文日韩在线| 91免费高清视频| 欧美性高潮床叫视频| 国产精品一区二区久久久| 色av中文字幕一区| 91久久精品美女| 日本精品视频在线播放| 国产91av在线| 国产一区二区三区在线免费观看| 精品美女久久久久久免费| 色综合男人天堂| 日韩精品中文字| 亚洲综合在线小说| 日本老师69xxx| 欧美日韩在线视频一区| 久久6免费高清热精品| 成人妇女淫片aaaa视频| 中文字幕欧美亚洲| 亚洲专区中文字幕| 爽爽爽爽爽爽爽成人免费观看| 91精品视频网站| 亚洲国产成人精品久久| 国产精品白丝jk喷水视频一区| 国产日韩欧美在线视频观看| 欧美性资源免费| 国产婷婷色综合av蜜臀av| x99av成人免费| 91热精品视频| 欧美日韩美女在线| 日韩黄色av网站| 孩xxxx性bbbb欧美| 国产午夜精品视频免费不卡69堂| 欧美国产中文字幕| 国产成人精品午夜| 狠狠色狠狠色综合日日五| 国产精品青草久久久久福利99| 怡红院精品视频| 亚洲自拍偷拍视频| 国产成人在线一区| 欧美成人黄色小视频| 7777免费精品视频| 色妞色视频一区二区三区四区| 日韩av一卡二卡| 国产精品青草久久久久福利99| 日韩免费在线观看视频| 国产精品露脸av在线| 96pao国产成视频永久免费| 欧美视频中文在线看| 国产97人人超碰caoprom| 日韩成人在线网站| 欧美高清在线观看| 在线播放精品一区二区三区| 欧美日韩一区二区在线播放| 午夜精品一区二区三区av| 91在线精品播放| 精品自拍视频在线观看| 亚洲女人天堂成人av在线| 91国语精品自产拍在线观看性色| 伊人成人开心激情综合网| 亚洲视频在线观看免费| 国产精品欧美日韩久久| 欧美日韩午夜视频在线观看| 国产精品丝袜一区二区三区| 久久久视频精品| 精品网站999www| 国产午夜精品久久久| 欧美xxxx18性欧美| 亚洲国产成人在线视频| 国产精品自产拍高潮在线观看| 欧美激情乱人伦| 亚洲国语精品自产拍在线观看| 精品久久久久久中文字幕一区奶水| 国产丝袜一区二区三区免费视频| 在线电影欧美日韩一区二区私密| 中文字幕亚洲欧美日韩2019| 国产精品wwww| 亚洲欧美日韩另类| 北条麻妃久久精品| 国产欧美亚洲视频| 欧美一级片免费在线| 国产一区私人高清影院| 欧美电影第一页| 国产精品成人一区二区三区吃奶| 国产成人精品免费久久久久| 91系列在线观看| 日本在线精品视频| 日韩一区二区在线视频| 国产精品久久久久久久久久新婚| 91成人在线观看国产| 97香蕉超级碰碰久久免费软件| 亚洲女同性videos| 亚洲精品在线观看www| 国产香蕉一区二区三区在线视频| 岛国av一区二区| 日韩电影中文 亚洲精品乱码| 在线观看国产成人av片| 日本sm极度另类视频| 亚洲精品国产精品自产a区红杏吧| 亚洲淫片在线视频| 久久亚洲春色中文字幕| 国产精品专区第二| 久久99热精品| 日韩av电影手机在线观看| 亚洲精品乱码久久久久久按摩观|