简朴使用
module.exports = { //... module: { rules: [ { test: /\.js$/, use: [ { // loader 是导出为一个a函数的 node 模块。该函数在 loader 转换资源的时刻挪用 // 给定的函数将挪用 loader API,并通过 this 上下文接见 loader: path.resolve('loader.js'), options: {/* ... */} } ] } ] } };
回首了loader的界说及简朴使用后,我们再来剖析一下实现loader的思绪
基于上面剖析的几点,我们更先着手
// 这个就是一个最简朴loader, // 若是我们的loader有依赖其它模块,也得以module的写法将在在顶部引入 import fs from 'fs'; export default function(source){ return source }
我们发现上面直接使用了return,是因为是同步类的loader且返回的内容唯一,若是你希望你的loader支持链式挪用,将效果返给下一个loader继续使用,这时刻就需要用webpack提供的api
这里我们简朴看一下this.callback的界说,一个可以同步或者异步挪用的可以返回多个效果的函数。预期的参数是
this.callback( err: Error | null, content: string | Buffer, sourceMap?: SourceMap, meta?: any )
// loader-utils 它提供了许多有用的工具 // 最常用的一个就是获取传入 loader 的 options import { getOptions } from 'loader-utils'; export default function(source, other) { const options = getOptions(this) // do whatever you want // ... this.callback(null, source, other) }
手写一个loader对没有研究过的听上去似乎有点难,事实上, 掌握上面所先容的内容及头脑,就可以更先写一个简朴的 Loader 了, 我们再来用简朴的代码绥一下loader到底是什么?
// 首先loader它是一个node模块,这很好明白 export const lessToCss = function(source, other) { // source 就是你即将要转换的文件源 // TODO // 将转换好的文件源流转至一个管道 this.callback(null, source, other) }
loader api中有几个好用的家伙这里就顺便带一下
下方贴上less-loader的源码,代码很简练,连系上方我们所剖析的,也很容易明白
import processResult from './processResult'; const render = pify(less.render.bind(less)); function lessLoader(source) { const loaderContext = this; const options = getOptions(loaderContext); const done = loaderContext.async(); const isSync = typeof done !== 'function'; if (isSync) { throw new Error( 'Synchronous compilation is not supported anymore. See https://github.com/webpack-contrib/less-loader/issues/84' ); } processResult(loaderContext, render(source, options)); }
1.阿里云: 本站现在使用的是阿里云主机,平安/可靠/稳固。点击领取2000米代金券、领会最新阿里云产物的种种优惠流动点击进入
支付宝蚂蚁庄园5月13日答题答案是什么,答对即可领取小鸡饲料180G,5月13日今天小鸡宝宝考考你的问题是:憋回去的屁最终很可能?可能有很多小伙伴不知道本次题目的正确答案,一起来看看5月13日支付宝小...
培训班是军事化管理,平时的上课时间手机不准带进教学区,学员们只有在晚上回到宿舍,才可以给家里打个电话。 刘悦大学毕业后,放弃电力公司的工作,来到“女生当男生使”的特训班。半年下来,刘悦可以连做俯...
怎么远程监控老公微信聊天(微信同步在线不被发现)相信不少用户都在网上搜索“如何监控手机微信聊天记录”等等,不过或许有很多事情会让人失望,付钱后,却不能做到监控,而只是短暂的将记录直接导出查看。无法...
亨氏宝宝米粉口味如何,亨氏宝宝米粉怎么样吃,亨氏宝宝米粉如何,亨氏宝宝米粉小宝宝爱吃吗,我就而言讲吧。 商品总体 接到商品很意外惊喜,包裝精美,外边也有泡沫膜裹住,三种口感,觉得非常好 闪光点与...
一个手机怎么装两个微信? [专业]安卓系统的手机能直接下载微信,下载步骤如下:1、打开手机浏览器。2、输入“微信”进行搜索。3、选择微信版本后点。 在电脑上,打开搜索,输入微信共存版,并搜索。进入网页...
“松原伴游-【卫虹】” 服务时间:七月八月九月身高170cm,体重50kg,学历为本科,是一位清纯美女,清新萝莉,极品模特的00后女生,她从事的其她职业包括:在校学生,愿意与适合的游伴结伴旅游去往...