webpack loader

1、分类

2、执行顺序

配置类型

执行顺序是 loader1>loader2>loader3

3、使用方式

自己的第一个loader

同步loader

javascript 复制代码
/**
 * loader 就是一个函数
 * 当webpack 解释资源时, 会调用相应的loader去处理
 * loader 接收到文件内容作为参数,返回文件内容
 * @param {*} content 文件内容
 * @param {*} map SourceMap
 * @param {*} meta 别的loader 传递过来的数据
 */
module.exports = function(content, map, meta){
    console.log('main.js 传过来的数据', content);
    return content
}

/**
 * 当需要传递参数给其他 loader 的loader 写法
 */

// module.exports = function (content,map, meta) {
//     // 第一个参数: err 代表是否有错误
//     // 第二个参数:content 处理后的内容
//     // 第三个参数: source-map 继续传递source-map
//     // 第四个参数:meta 给下一个loader传递参数
//     this.callback(null,content,map,meta);
// }

会在vscode 终端看到

异步loader (同步loader不能调用异步方法)

javascript 复制代码
module.exports = function(content, map, meta){
    const callback = this.async()

    setTimeout(()=>{
        console.log('异步操作');
        callback(null, content, map, meta)

    }, 1000)
}

raw loader,处理图片、svg等时会用到

javascript 复制代码
// 同步异步操作均可以
module.exports = function(content, map, meta){
    console.log('raw-loader Buffer数据流', content);
    return content
}

module.exports.raw = true

目前 只有 main.js 文件

javascript 复制代码
console.log('hello word');

patch loader

执行顺序

javascript 复制代码
// pitch-loader1.js
module.exports = function(content, map, meta){
    console.log('pitch-loader1');
    return content
}

module.exports.pitch = function(content, map, meta){
    console.log('pitch1');
}


//  pitch-loader2.js
module.exports = function(content, map, meta){
    console.log('pitch-loader2');
    return content
}

module.exports.pitch = function(content, map, meta){
    console.log('pitch2');
}

// pitch-loader.js
module.exports = function(content, map, meta){
    console.log('pitch-loader3');
    return content
}

module.exports.pitch = function(content, map, meta){
    console.log('pitch3');
}

webpack.config.js 配置

打印结果

如果patch中有return 则不糊执行后续的操作,而是直接返回到上一个loader执行,如果没有就不用执行,下面是在loader中有返回值的意思,直接返回到loader执行操作

4、loader Api

this.getOptions获取options

schema.json

打包后文件中就会多出坐着相关信息

5、简单重写一下常用的部分loader

babel-loader

javascript 复制代码
const babel = require('@babel/core')
const schema = require("./schema.json")

module.exports = function(content, map, meta){
    // 获取webpack 使用这个loader 时的options配置项
    const callback = this.async()
    const options = this.getOptions(schema)

    babel.transform(content, options, function(err, result){
        if(err) callback(err)
        else callback(null, result.code)
    })
}

schema.json

javascript 复制代码
{
    "type":"object",
    "properties":{
        "presets":{
            "type": "array"
        }
    },
    "additionalProperties": false
}

webpack 中的使用

file-loader (使用到this.emitFile函数)

webpack 配置

stylle-loader

主要作用,通过js代码创建一个style标签 ,然后将样式代码加进去

这里 module.exports = function(){} 空函数即可

如果,想要更深一步学习loader, 可以去看看常用的loader的源码

相关推荐
Dontla9 小时前
Webpack DefinePlugin插件介绍(允许在编译时创建JS全局常量,常量可以在源代码中直接使用)JS环境变量
运维·javascript·webpack
隐含13 小时前
webpack打包,把png,jpg等文件按照在src目录结构下的存储方式打包出来。解决同一命名的图片资源在打包之后,重复命名的图片就剩下一个图片了。
前端·webpack·node.js
胡桃夹夹子13 小时前
【前端优化】vue2 webpack4项目升级webpack5,大大提升运行速度
前端·javascript·vue.js·webpack·性能优化
GISer_Jing2 天前
编译原理AST&以Babel为例进行解读、Webpack中自定义loader与plugin
前端·webpack·node.js
GISer_Jing2 天前
Webpack中Compiler详解以及自定义loader和plugin详解
前端·webpack·node.js
cdcdhj3 天前
vue用通过npm的webpack打包编译,这样更适合灵活配置的项目
vue.js·webpack·npm
augenstern4164 天前
webpack重构优化
前端·webpack·重构
Dontla5 天前
何时需要import css文件?怎么知道需要导入哪些css文件?为什么webpack不提示CSS导入?(导入css导入规则、css导入规范)
前端·css·webpack
积极向上的龙5 天前
首屏优化,webpack插件用于给html中js自动添加异步加载属性
javascript·webpack·html
Attacking-Coder5 天前
前端面试宝典---webpack面试题
前端·面试·webpack