webpack之理解loader
我们在写webpack配置文件的时候,应该有注意到经常用到loader这个配置项,那么loader是用来做什么的呢?
loader其实是用来将源文件经过转化处理之后再输出新文件。
如果是数组形式的话,它的执行顺序是相反的,最后一个loader最早被调用,下一个loader传入的是上一个loader的返回结果。
基础的loader文件
首先在webpack.config.js里调用新建的loader文件
const path = require('path');
module.exports = {
    module: {
        rules: [
            {
                test: /\.js$/,
                exclude: /node_modules/,
                use: {
                    loader: path.resolve('./loader/index.js'),
                    options: {}
                }
            }
        ]
    }
}
代码在传入loader文件的时候已经被转为string了,loader文件最终也必须返回string数据。loader文件里代码如下:
module.exports = function (content) {
    console.log('loader文件', content);
    return content;
}
获取options配置数据
webpack.config.js文件里,在配置loader的同时,还可以配置options。
const path = require('path');
module.exports = {
    module: {
        rules: [
            {
                test: /\.js$/,
                exclude: /node_modules/,
                use: {
                    loader: path.resolve('./loader/index.js'),
                    options: {
						data: ’自定义的配置'
					}
                }
            }
        ]
    }
}
在loader文件里面可以利用webpack提供的loader-utils来获取options。
const loaderUtils = require('loader-utils');
module.exports = function (content) {
    // this是loader函数的执行上下文
    const options = loaderUtils.getOptions(this);
    console.log('配置文件', options); // {data:'自定义的配置'}
    return content;
}
异步loader
之前举的例子都是在同步的情况下,那么在异步的情况中,必须调用this.async()来告知loader等待异步结果,它会返回this.callback()回调函数,这时候loader必须返回undefined
module.exports = function(content) {
  const callback = this.async();
  someAsyncOperation(content, function(err, result) {
    if (err) return callback(err);
    callback(null, result, map, meta);
  });
};
总结
开头就提到过了,loader实质上是用来处理源文件的,在loader函数里面一般都会对代码进行转化处理,这里就会用到AST,将代码转换为AST方便对代码进行处理。
webpack之理解loader的更多相关文章
- webpack 中,loader、plugin 的区别
		
loader 和 plugin 的主要区别: loader 用于加载某些资源文件. 因为 webpack 只能理解 JavaScript 和 JSON 文件,对于其他资源例如 css,图片,或者其他的 ...
 - 初探webpack之编写loader
		
初探webpack之编写loader loader加载器是webpack的核心之一,其用于将不同类型的文件转换为webpack可识别的模块,即用于把模块原内容按照需求转换成新内容,用以加载非js模块, ...
 - webpack打包理解
		
webpack打包理解(将所有依赖文件打包到一个文件中) 由于前端代码变得越来越多,越来越复杂, 纯粹脚本化的代码书写方式已经不能满足工程化得需求. 前端模块被抽象出来, 不仅仅包括js模块, 其它如 ...
 - webpack CSS处理loader
		
loader概念: 首先来介绍一下loader,之前我们用webpack来处理我们写的js代码,并且webpack会自动处理js之间相关的依赖.但是,在开发中我们不仅仅有基本的js代码处理,我们也需要 ...
 - webpack系列之loader的基本使用
		
可以访问 这里 查看更多关于大数据平台建设的原创文章. webpack系列之loader及简单的使用 一. loader有什么用 webpack本身只能打包Javascript文件,对于其他资源例如 ...
 - Webpack学习-Loader
		
什么是Loader? 继上两篇文章webpack工作原理介绍(上篇.下篇),我们了解到Loader:模块转换器,也就是将模块的内容按照需求装换成新内容,而且每个Loader的职责都是单一,只会完成一种 ...
 - Vue系列之 => webpack的url loader
		
安装: npm i url-loader file-loader -D //url-loader内部依赖file-loader webpack.config.js const path = requ ...
 - webpack - HtmlWebpackPlugin理解
		
该插件的两个主要作用: 为html文件中引入的外部资源如script.link动态添加每次compile后的hash,防止引用缓存的外部文件问题 可以生成创建html入口文件,比如单页面可以生成一个h ...
 - webpack配置常用loader加载器
		
webapck中使用loader的方法有三种 使用loader之前必须运行安装 : npm install --save-dev xxx-loader (1)通过CLI : 命令行中运行 webpac ...
 
随机推荐
- radio中最佳解决方案
			
radio中最佳解决方案 1.html中 <td> <input id="status" name="status" type="r ...
 - C++异常安全
			
转自:http://www.cnblogs.com/zgfLawliet/p/3417308.html 异常安全的代码是指,满足两个条件 1异常中立性 : 是指当你的代码(包括你调用的代码)引发异 ...
 - 安装和测试Kafka
			
本文主要介绍如何在单节点上安装 Kafka 并测试 broker.producer 和 consumer 功能. 下载 进入下载页面:http://kafka.apache.org/downloads ...
 - console和windows子系统
			
https://blog.csdn.net/ilvu999/article/details/8050292
 - OSPF-DR与BDR的选举及作用
			
IERS-DR与BDR的选举及作用 一.问题引出 在运行OSPF的MA网络中包括广播型和NBMA网络会存在两个问题: 1).在一个有n个路由器的网络中,会形成(n*(n-1))/2邻居关系. 2).邻 ...
 - Grunt 使用(一)基础搭建
			
jQuery在使用grunt,bootstrap在使用grunt,百度UEditor在使用grunt,你没有理由不学.不用!废话不多说,直接上干货. 1.安装node.js并检查node -v 和 n ...
 - mongodb---js脚本操作速记
			
之前写一些mongodb的同步或操作程序,往往使用perl,甚至c实现,这样程序很繁琐,而且逻辑不好控制,甚至一些功能和命令什么的,在这些语言的mongo驱动中就没有实现.后来发现mongodb 的s ...
 - Linux-python的一些小问题
			
1.python版本和pip版本 2.PATH和PYTONPATH 1.python版本和pip版本 1.python版本 一般Ubuntu里面都装的不止一个版本的python,比如有python2. ...
 - System IPC 与Posix IPC(semaphore信号灯)
			
POSIX下IPC主要包括三种: posix message queue posix semaphores posix shared memory sysytem v IPC包括: system v ...
 - 迷宫问题——BFS
			
改进版 BFS #include <bits/stdc++.h> using namespace std; #define coordi(x,y) ( m*(x-1)+y ) const ...