如何寫一個Loader

如何寫一個Loader

由于webpack只能解析Javascript與JSON語句舌胶。于是webpack加入了Loader的概念则酝。

Loader用于將其他語言轉(zhuǎn)化為能被webpack理解的模塊。

// Loader的基礎使用:
const path = require('path');

module.exports = {
  module: {
    rules: [{ test: /\.txt$/, use: 'raw-loader' }],
  },
};

接下來我們寫一個簡單的loader瞭亮。

首先新建一個項目并導入webpack。

yarn init
yarn add webpack webpack-cli

添加index.js與一個轉(zhuǎn)化目標/fish/index.fish

// index.js
import Fish from './fish/index.fish'

console.log(Fish)

// /fish/index.fish
I'm byFish

添加一個自定義的Loader文件

// /loader/index.js
module.exports = function(source) {
    return `export default ${JSON.stringify(source)}`
}

添加webpack.config.js文件,配置webpack

const path = require('path');

module.exports = {
  entry: './index.js',
  output: {
    path: path.resolve(__dirname, 'dist'),
    filename: 'bundle.js',
  },
  mode: 'production',
  module: {
    rules: [
      {
        test: /\.fish$/,
        use: [
          {
            loader: path.resolve('loader/index.js'),
            options: {
              /* ... */
            },
          },
        ],
      },
    ],
  },
};

在package.json中加入構(gòu)建命令

{
    ...
  "scripts": {
    "build": "webpack"
  }
  ...
}

運行后查看/dist/bundle.js,已成功編譯哮翘。

(()=>{"use strict";console.log("I'm byFish")})();

在webpack.config.js可以加入options字段颈嚼,傳遞參數(shù)。Loader中使用this.getOptions()可以接收到

// webpack.config.js
options: {
    addEnd: true,
}

// loader文件
module.exports = function(source) {
    const {addEnd} = this.getOptions()
    const result = `"${JSON.stringify(source).slice(1, -1)}${addEnd ? ' end' : ''}"`
    return `export default ${result}`
}

輸出將變成

(()=>{"use strict";console.log("I'm byFish end")})();

在異步或者更復雜的情況下Loader可以使用this.callback()來返回值饭寺。

參考

https://webpack.js.org/contribute/writing-a-loader/

https://webpack.js.org/concepts/loaders/

https://glebbahmutov.com/blog/writing-webpack-loader/

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末阻课,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子艰匙,更是在濱河造成了極大的恐慌限煞,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,122評論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件员凝,死亡現(xiàn)場離奇詭異署驻,居然都是意外死亡,警方通過查閱死者的電腦和手機健霹,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,070評論 3 395
  • 文/潘曉璐 我一進店門旺上,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人糖埋,你說我怎么就攤上這事宣吱。” “怎么了瞳别?”我有些...
    開封第一講書人閱讀 164,491評論 0 354
  • 文/不壞的土叔 我叫張陵征候,是天一觀的道長杭攻。 經(jīng)常有香客問我,道長疤坝,這世上最難降的妖魔是什么兆解? 我笑而不...
    開封第一講書人閱讀 58,636評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮卒煞,結(jié)果婚禮上痪宰,老公的妹妹穿的比我還像新娘。我一直安慰自己畔裕,他們只是感情好衣撬,可當我...
    茶點故事閱讀 67,676評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著扮饶,像睡著了一般具练。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上甜无,一...
    開封第一講書人閱讀 51,541評論 1 305
  • 那天扛点,我揣著相機與錄音,去河邊找鬼岂丘。 笑死陵究,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的奥帘。 我是一名探鬼主播铜邮,決...
    沈念sama閱讀 40,292評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼寨蹋!你這毒婦竟也來了松蒜?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,211評論 0 276
  • 序言:老撾萬榮一對情侶失蹤已旧,失蹤者是張志新(化名)和其女友劉穎秸苗,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體运褪,經(jīng)...
    沈念sama閱讀 45,655評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡惊楼,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,846評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了秸讹。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片胁后。...
    茶點故事閱讀 39,965評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖嗦枢,靈堂內(nèi)的尸體忽然破棺而出攀芯,到底是詐尸還是另有隱情,我是刑警寧澤文虏,帶...
    沈念sama閱讀 35,684評論 5 347
  • 正文 年R本政府宣布侣诺,位于F島的核電站殖演,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏年鸳。R本人自食惡果不足惜趴久,卻給世界環(huán)境...
    茶點故事閱讀 41,295評論 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望搔确。 院中可真熱鬧彼棍,春花似錦、人聲如沸膳算。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,894評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽涕蜂。三九已至华匾,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間机隙,已是汗流浹背蜘拉。 一陣腳步聲響...
    開封第一講書人閱讀 33,012評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留有鹿,地道東北人旭旭。 一個月前我還...
    沈念sama閱讀 48,126評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像葱跋,于是被迫代替她去往敵國和親持寄。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,914評論 2 355

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

  • loader loader 用于對模塊的源代碼進行轉(zhuǎn)換年局。loader 可以使你在 import 或 "load(加...
    夢想成真213閱讀 928評論 0 0
  • 前言 Loader(加載器) 是 webpack 的核心之一。它用于將不同類型的文件轉(zhuǎn)換為 webpack 可識別...
    champyin閱讀 407評論 0 1
  • Study Notes[https://wuner.gitee.io/wuner-notes/fed-e-task...
    Wuner閱讀 478評論 0 0
  • 文:小 boy(滬江網(wǎng)校Web前端工程師) 本文原創(chuàng)咸产,轉(zhuǎn)載請注明作者及出處 經(jīng)常逛 webpack 官網(wǎng)的同學應該...
    iKcamp閱讀 8,065評論 4 22
  • 對于webpack矢否,一切皆模塊。webpack 只能理解 JavaScript 和 JSON 文件脑溢,其他類型/后綴...
    AizawaSayo閱讀 5,910評論 0 3