自定义loader基础知识
参考 :译文 编写一个loader
https://webpack.github.io/docs/loaders.html
按照loader的返回值可以分为两种:
- 最左loader:这种loader会返回字符串描述的js模块代码,已经是loader的最终处理结果了,这样的字符串会被添加到webpack的模块函数中
- 非最左loader:返回值不是js模块代码,而仅仅是对资源的中间处理结果,这样的字符串需要被后续的loader处理
一般情况下,在loader的链式调用中,一般是这样:最左loader!非最左loader!非最左loader ....
简单loader例子
- // loaders/myLoader.js 返回的值是js模块代码,这个loader属于最左loader
- module.exports = function loader(source) {
- return `module.exports = {fn: ${source}}`;
- };
- // main.js
- const src = require("./src")
- src.fn();
- // src.js
- alert(999)
- //配置文件
- const path = require('path')
- module.exports = {
- entry: [__dirname + "/main.js"],
- output: {
- path: __dirname + "/dist",
- filename: "bundle.js",
- },
- module: {
- loaders:[
- {
- test: /src.js/,
- use: [
- {
- loader: path.resolve(__dirname, './loaders/myLoader.js'),
- }
- ]
- }
- ]
- }
- }
打包后的结果
- /***/ }),
- /* 1 */
- /***/ (function(module, exports, __webpack_require__) {
- const src = __webpack_require__(2)
- src.fn();
- /***/ }),
- /* 2 */
- /***/ (function(module, exports) {
- module.exports = {fn: alert(999)}
- /***/ })
- /******/ ]);
注意:如果loader处理的是所有js,则入口文件是js的话也会被处理。
从以上代码可以看出,对于某些loader,他们导出的结果可能并不重要,而是可以在导出之前,根据拿到的文本内容对页面做一些操作。
aync loader
把以上小例子中的loader定义为:
- module.exports = function(source) {
- var callback = this.async();
- setTimeout(function(){
- callback(null,`module.exports = {fn: ${source}}`)
- },5000);
- };
启动打包后,经过5s才打包完成。打包结果和以上小例子中的一致。
pitching loader
在loader函数对象上添加一个pitch属性,这个pitch所执行的函数称为pitching loader。在pitching loader中可以通过data把数据传递给对应的loader,而不能传递给其他loader。
在链式调用中,pitching loader 与 loader的执行次序(以 a!b!c!resource 为例):
- pitch
a
- pitch
b
- pitch
c
- read file
resource
(addsresource
to dependencies)
- read file
- run
c
- pitch
- run
b
- pitch
- run
a
在pitching loader有返回值时的情况
- pitch
a
- pitch
b
(returns something)
- pitch
- run
a
可见,哪个pitching loader有返回值,则对应的loader以及后续的loader都不执行了。以上例子中a loader函数的第一个参数就是b pitching loader的返回值。
pitching loader的应用场景
问题是有时候我们想把两个第一种loader chain起来,比如
- style-loader!css-loader
而 css-loader
的返回值是一串js代码(包含了module.export=xxx这样的字符串),如果按正常方式写style-loader
的参数就是一串代码字符串。就算eval
了也不一定拿到什么值:
- eval('module.export="result";console.log("hello world")') === "hello world"
为了解决这种问题,我们需要在style-loader
里执行require(css-loader!resouce)
, 这会把css-loader
跑一遍,也就是说如果按正常顺序执行css-loader
会跑两遍(第一遍拿到的js代码用不了), 为了只执行一次,style-loader
利用了pitching
, 在pitching
函数里require(css-loader!resouce)
。然后返回js代码(style-loader能够作为最左边loader)
自定义loader基础知识的更多相关文章
- Java自定义注解基础知识
注解分为三类:没有任何元素的注解,有一个元素的注解和有多个元素的注解. 1. Marker注解 这类注解没有任何元素,此类注解仅仅是一个标示.如下所示: public @interface Good ...
- ASP.NET基础知识汇总之WebConfig自定义节点详细介绍
之前介绍过Webconfig的具体知识ASP.NET基础知识汇总之WebConfig各节点介绍.今天准备封装一个ConfigHelper类,涉及到了自定义节点的东东,平时虽然一直用,但也没有系统的总结 ...
- php面试笔记(5)-php基础知识-自定义函数及内部函数考点
本文是根据慕课网Jason老师的课程进行的PHP面试知识点总结和升华,如有侵权请联系我进行删除,email:guoyugygy@163.com 在面试中,考官往往喜欢基础扎实的面试者,而函数相关的考点 ...
- TestStand 基础知识[7]--Build-in Step Types (2)
接着上一篇文章:TestStand 基础知识[6] Build-In StepTypes(1) 继续介绍: 还是先把Build-in StepTypes图片贴一下, 1. Call Executabl ...
- .NET面试题系列[1] - .NET框架基础知识(1)
很明显,CLS是CTS的一个子集,而且是最小的子集. - 张子阳 .NET框架基础知识(1) 参考资料: http://www.tracefact.net/CLR-and-Framework/DotN ...
- Java基础知识(壹)
写在前面的话 这篇博客,是很早之前自己的学习Java基础知识的,所记录的内容,仅仅是当时学习的一个总结随笔.现在分享出来,希望能帮助大家,如有不足的,希望大家支出. 后续会继续分享基础知识手记.希望能 ...
- IOS开发基础知识碎片-导航
1:IOS开发基础知识--碎片1 a:NSString与NSInteger的互换 b:Objective-c中集合里面不能存放基础类型,比如int string float等,只能把它们转化成对象才可 ...
- 学习 shell脚本之前的基础知识
转载自:http://www.92csz.com/study/linux/12.htm 学习 shell脚本之前的基础知识 日常的linux系统管理工作中必不可少的就是shell脚本,如果不会写sh ...
- 基础知识《十》unchecked异常和checked异常
运行时异常在运行期间才能被检查出来,一般运行期异常不需要处理.也称为unchecked异常.Checked异常在编译时就能确定,Checked异常需要自己处理. checked 异常也就是我们经常遇到 ...
随机推荐
- CF1076D Edge Deletion
洛谷传送门 cf传送门 这道题作为div.2的D题,被我一眼秒了我觉得十分荣幸,然后就开始写,然后就写了好久. AC之后看网上的题解,发现好多最短路树的,猛然发现我写的好复杂啊,结果还看到了直接一遍d ...
- python模块之hmac
# hmac模块使用步骤: # hmac模块模块的使用步骤与hashlib模块的使用步骤基本一致,只是在第1步获取hmac对象时,只能使用hmac.new()函数, # 因为hmac模块没有提供与具体 ...
- python 基础(四) 函数
函数 一.什么是函数? 函数是可以实现一些特定功能的 小方法 或者是小程序 优点: 提高 了代码的后期维护 增加了代码的重复使用率 减少了代码量 提高了代码可读性 二.函数的定义 使用 def关键+函 ...
- Qt 进程和线程之一:运行一个进程和进程间通信
Qt提供了对进程和线程的支持.本节讲述了怎样在Qt应用程序中启动一个进程,以及几种常用的进程间通信方法.如果对进程和线程的概念不是很了解,可以看我的另一篇博客:[多进程和多线程的概念. 设计应用程序时 ...
- UVa12304(计算几何中圆的基本操作)
断断续续写了250多行的模拟,其间被其他事情打扰,总共花了一天才AC吧~ 这道题目再次让我明白,有些事情看起来很难,实际上并没有我们想象中的那么难.当然了我主要指的不是这个题的难度…… 也是初学计算几 ...
- vue初级学习--使用 vue-resource 请求数据
一.导语 我发现好像我最近几次写文,都是在7号,很恰巧啊~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ...
- 17999 Light-bot 模拟 + kmp求循环节
http://acm.scau.edu.cn:8000/uoj/mainMenu.html 17999 Light-bot 时间限制:1000MS 内存限制:65535K 提交次数:0 通过次数:0 ...
- equals方法那些事
1.Equals 很多人对equals方法的用法有些模糊,这里来为大家梳理下: 字符串中的equals方法,该方法用来判断两个字符串的内容是否相同. 例1: String str1="Hel ...
- Spring Cloud Config git版
由于在学习这块内容的时候还不会使用gitHub所以就用了osc的码云 config server POM文件 <dependency> <groupId>org.springf ...
- mysql实现计数器
本文转自:https://blog.csdn.net/stevendbaguo/article/details/70889449 如果是在非常高的并发之下,还是建议用内存数据库redis去实现计数的功 ...