我们在写webpack配置文件的时候,应该有注意到经常用到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;
}
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: ’自定义的配置'
}
}
}
]
}
}
在lo在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;
}
之前举的例子都是在同步的情况下,那么在异步的情况中,必须调用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方便对代码进行处理,之后我会有另一篇文章来介绍AST。
来自:https://www.cnblogs.com/minz/archive/2019/04/03/10651965.html
webpack的loaders是一块很重要的组成部分。我们都知道webpack是用于打包的,里面的所有资源都是“模块”,内部实现了对模块资源进行加载的机制。loader的作用为了转换应用程序的资源文件。
知道在webpack中使用scss,less之类的东西,需要配置style-loader, css-loader, sass-loader这些,但是在vue-cli的项目中会报Invalid CSS after ...load the styles的错误,这是由于loader重复加载导致的。
方案一:使用lib-flexible包:使用flexible包方式,安装 lib-flexible 包和 px2rem-loader包;方案二:使用less或者sass等CSS 预处理语言写适配方案:基准按照设计图尺寸,但是缺点是不通用,不同页面可能设计图基准尺寸不同
那是因为,webpack 默认只支持打包 Javascript 模块,比如 import m1 from m1.js,而对于引入了图片模块,webpack 并不知道该如何处理,因此在打包的时候就报错了。对于上述打包图片资源报错的问题
通过配置 name 和 outputPath 选项,可以自定义图片名称和路径。打包后,dist 目录下会生成一个 images 文件夹;url-loader 将图片转化成 base 编码字符串和 main.js 打包在一起。
`babel-loader` 是一个 npm 包,它使得 webpack 可以通过 babel 转译 JavaScript 代码。babel 的功能在于「代码转译」,具体一点,即将目标代码转译为能够符合期望语法规范的代码。在转译的过程中
整理一些常用的loader分享给大家,方便知道在什么场景下该用什么loader。如果有大佬都懂悄悄左滑就行,不喜勿喷。style-loader用于将css编译完成的样式,挂载到页面style标签上。
项目中常常会引入一些图片资源,什么jpg|jpeg|png|gif|ico之类的,正常情况下,我们需要做一下性能优化,看看如何大而化小、小而化了,提升生产环境资源加载速度。所以,本文记录一下大图片使用image-webpack-loader插件压缩一下
用过webpack的朋友一定知道webpack中有个loader的概念,用于加载并处理不同类型文件,比如css-loader、url-loader。loader的执行顺序取决于webpack内部对文件树解析、遍历的顺序。
内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!