webpack loader实现
正值前端组件化开发时代,那么必然离不开目前最火的构建工具——webpack(grunt,gulp等暂且不谈)。说到这里,刚好有几个问题:
- 为什么运行打包命令之后,
.vue
文件可以转成.js
文件 - 为什么运行打包命令之后,
.less
文件可以转成.css
文件 - 为什么运行打包命令之后,
ES6+
语法可以转成ES5
语法
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-mr86zPPH-1570953160209)(https://img.shields.io/npm/v/vue-hash-calendar.svg)]
上面这几个问题,就引出了我们的主角——【loader】。
loader
是webpack
的一块很重要的组成部分。我们都知道webpack
是用于资源打包的,里面的所有资源都是“模块”,内部实现了对模块资源进行加载的机制。但是Webpack
本身只能处理js
模块,如果要处理其他类型的文件,就需要使用loader
进行转换。Loader
可以理解为是模块和资源的转换器,它本身是一个函数,接收文件源码作为参数,返回转换的结果,例如可以使用loader
加载器可以快速编译预处理器(less,sass,coffeeScript)
。Loader
可以在require()
引用模块的时候添加,也可以在webpack
全局配置中进行绑定,还可以通过命令行的方式使用。(本篇中的参数配置及使用方式均基于webpack4.0
版本)
一、loader的特点
1、loader
的执行顺序和代码书写的顺序是相反的,即:从下至上,从右至左。
2、第一个执行的 loader
会接收源文件做为参数,下一次执行的 loader
会接收前一个 loader
执行的返回值做为参数
3、需要严格遵循“单一职责”原则,即每个 loader
只负责自己需要负责的事情
二、loader API
methods | 含义 |
---|---|
this.request | 被解析出来的 request 字符串。例子:"/abc/loader1.js?xyz!/abc/node_modules/loader2/index.js!/abc/resource.js?rrr" |
this.loaders | 所有 loader 组成的数组。它在 pitch 阶段的时候是可以写入的。 |
this.loaderIndex | 当前 loader 在 loader 数组中的索引。 |
this.async | 告诉 loader-runner 这个 loader 将会异步地回调 |
this.callback | 一个可以同步或者异步调用的可以返回多个结果的函数 |
this.data | 在 pitch 阶段和正常阶段之间共享的 data 对象。 |
this.cacheable | 设置是否可缓存标志的函数 |
this.resource | request 中的资源部分,包括 query 参数 |
this.resourcePath | 资源文件的路径。 |
this.resourceQuery | 资源的 query 参数 |
this.target | 编译的目标。从配置选项中传递过来的。 |
this.webpack | 如果是由 webpack 编译的,这个布尔值会被设置为真 |
this.sourceMap | 应该生成一个 source map。因为生成 source map 可能会非常耗时,你应该确认 source map 确实有必要请求。 |
this.emitWarning | 发出一个警告。 |
this.emitError | 发出一个错误。 |
this.loadModule | 解析给定的 request 到一个模块,应用所有配置的 loader ,并且在回调函数中传入生成的 source 、sourceMap 和 模块实例(通常是 NormalModule 的一个实例)。如果你需要获取其他模块的源代码来生成结果的话,你可以使用这个函数。 |
this.resolve | 像 require 表达式一样解析一个 request 。 |
this.emitFile | 产生一个文件。这是 webpack 特有的。 |
this.fs | 用于访问 compilation 的 inputFileSystem 属性。 |
this.value | 向下一个 loader 传值。如果你知道了作为模块执行后的结果,请在这里赋值(以单元素数组的形式)。 |
this.inputValue | 从上一个 loader 那里传递过来的值。如果你会以模块的方式处理输入参数,建议预先读入这个变量(为了性能因素)。 |
更多详细API,以及各API的用法示例,可以访问官网查看。地址:https://www.webpackjs.com/api/loaders
三、写loader之前的需求整理
现在有这样一个需求,使用 hxkj-loader
加载并处理名称为 *.hxkj.vip
的文件,将里面的哈希空间
全部替换为 www.hxkj.vip
。需要实现的转换如下:
转换前的内容:
<div>
<h1>欢迎访问哈希空间</h1>
<p>哎哟,终于等到你。这里就是让人流连忘返的哈希空间呀!</p>
</div>
转换后的内容:
<div>
<h1>欢迎访问www.hxkj.vip</h1>
<p>哎哟,终于等到你。这里就是让人流连忘返的www.hxkj.vip呀!</p>
</div>
四、编写loader
在与 webpack.config.js
同级目录下新建 hxkj-loader.js
,文件的内容如下:
module.exports = function(source){
var content="";
content = source.replace("/哈希空间/g","www.hxkj.vip");
return content;
}
接下来,需要在 webpack.config.js
文件中增加以下的配置:
const path = require("path"); // 引入 node 的 path 模块
...
module:{
rules:[{
test: /\.hxkj\.vip$/, // 正则匹配以 hxkj.vip 结尾的文件
use:[{
loader:path.resolve(__dirname, "hxkj-loader") // 使用 path 模块找到 hxkj-loader 的路径
}]
}]
}
好,到此,一个简易版的 loader
就已经写完了。目前 loader
是直接写在本地的,可以考虑将自己写好的 loader
发布到 npm
,这样就更加完善了。
At last,看完之后有什么不懂的,可以留言反馈。
转载请注明出处:https://www.jianshu.com/p/51b793f6fa0e
作者:TSY
个人空间:https://hxkj.vip
webpack loader实现的更多相关文章
- 怎样写一个webpack loader
div{display:table-cell;vertical-align:middle}#crayon-theme-info .content *{float:left}#crayon-theme- ...
- 如何开发webpack loader
关于webpack 作为近段时间风头正盛的打包工具,webpack基本占领了前端圈.相信你都不好意思说不知道webpack. 有兴趣的同学可以参考下我很早之前的webpack简介 . 确实webpac ...
- 手把手教你撸一个 Webpack Loader
文:小 boy(沪江网校Web前端工程师) 本文原创,转载请注明作者及出处 经常逛 webpack 官网的同学应该会很眼熟上面的图.正如它宣传的一样,webpack 能把左侧各种类型的文件(webpa ...
- 案例实战之如何写一个webpack loader
通过以下几个实例掌握webpack loader的写法 1.写一个多语言替换的loader 在index.js在页面上插入了一个{{title}}文本,我们需要在打包的时候将其替换成对应的多语言 fu ...
- 发布一个npm包(webpack loader)
发布一个npm包,webpack loader: reverse-color-loader,实现颜色反转. 初始化项目 mkdir reverse-color-loader cd ./reverse- ...
- webpack loader & pulgin
webpack loader & plugin https://webpack.js.org/concepts/loaders/ https://webpack.js.org/concepts ...
- webpack loader加载器
配置loader,通过加载器处理文件,例如css sass less等,告诉webpack每一种文件都需要使用什么来加载器来处理. 1.node.js安装好之后也会自动默认安装好npm,所以cmd c ...
- [webpack]——loader配置
前言 当我们需要配置 loader 时,都是在 module.rules 中添加新的配置项,在该字段中,每一项被视为一条匹配使用 loader 的规则. 看一下基础实例: module.exports ...
- 使用webpack loader加载器
了解webpack请移步webpack初识! 什么是loader loaders 用于转换应用程序的资源文件,他们是运行在nodejs下的函数 使用参数来获取一个资源的来源并且返回一个新的来源(资源的 ...
- webpack loader 生成虚拟文件的方案
此文已由作者张磊授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. 前言 使用 webpack 的时候,难免需要写一些 loader,接着就会遇到一个很纠结的问题.该 loade ...
随机推荐
- Period UVALive - 3026
For each prefix of a given string S with N characters (each character has an ASCII code between 97 a ...
- 单细胞转录组测序数据的可变剪接(alternative splicing)分析方法总结
可变剪接(alternative splicing),在真核生物中是一种非常基本的生物学事件.即基因转录后,先产生初始RNA或称作RNA前体,然后再通过可变剪接方式,选择性的把不同的外显子进行重连,从 ...
- 【LeetCode】[0002] 【两数之和】
题目描述 思路分析 测试用例 Java代码 代码链接 题目描述 给出两个非空 的链表用来表示两个非负的整数.其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字.如果 ...
- 对TD tree系统评价及改进
该系统是由石家庄铁道大学2017级信息学院的同学研发并改进,分享给我们18级新生的一份体验,这项app可安装在任意一个智能手机上,当听到学长们像我们介绍这款app的时候,着实让我惊呆了,惊叹学长们的编 ...
- Mybatis源码阅读-配置文件及映射文件解析
Mybatis源码分析: 1.配置文件解析: 1.1源码阅读入口: org.apache.ibatis.builder.xml.XMLConfigBuilder.parse(); 功能:解析全局配置文 ...
- 2019沈阳网络赛B.Dudu's maze
https://www.cnblogs.com/31415926535x/p/11520088.html 啊,,不在状态啊,,自闭一下午,,都错题,,然后背锅,,,明明这个简单的题,,, 这题题面不容 ...
- FreeSql (十三)更新数据时忽略列
var connstr = "Data Source=127.0.0.1;Port=3306;User ID=root;Password=root;" + "Initia ...
- linux ssh连接自动断开问题
场景描述:云上的虚拟机使用public ip连接ssh时,一直提示已经连接,但是就会自动关闭 1. 通过正常虚拟机作为跳板,能够连接到目标机子上,检查发现进程正常,但是就一直连接不上 [root@te ...
- CTC安装错误之:binding.cpp:6:29: fatal error: torch/extension.h: No such file or directory
错误原因:该问题主要由于CTC的版本导致. 解决方法: 在终端打开warp-ctc文件夹: cd warp-ctc 然后:git checkout ac045b6072b9bc3454fb9f9f17 ...
- 搭建数据库galera集群
galera集群 galera简介 galera集群又叫多主集群,用于数据库的同步,保证数据安全 最少3台,最好是奇数台数,当一台机器宕掉时,因为仲裁机制,这台机器就会被踢出集群. 通过wsrep协议 ...