webpack:自定义loader

简介: webpack:自定义loader

以下是一个自定义loader replace-loader,实现一个类似模板引擎变量替换的简单功能


文件目录

.
├── dist
│   └── index.js            # 打包结果
├── loaders
│   └── replace-loader.js   # 自定义loader
├── src
│   └── index.js            # 要打包的文件入口
├── package.json            # 依赖配置
└── webpack.config.js       # 打包配置

package.json


{
  "name": "loader-demo",
  "version": "1.0.0",
  "description": "a webpack loader demo",
  "scripts": {
    "build": "webpack"
  },
  "devDependencies": {
    "loader-utils": "^2.0.0",
    "webpack": "^5.47.0",
    "webpack-cli": "^4.7.2"
  }
}

webpack.config.js


'use strict';
const path = require('path');
module.exports = {
  // 打包入口
  entry: {
    index: './src/index.js',
  },
  // 指定输出地址及打包出来的文件名
  output: {
    path: path.join(__dirname, 'dist'),
    filename: '[name].js',
  },
  // Loader路径
  resolveLoader: {
    modules: ['node_modules', './loaders'],
  },
  module: {
    rules: [
      {
        test: /.js$/,
        use: {
          loader: 'replace-loader',
          // 传递参数
          options: {
            name: 'Tom',
          },
        },
      },
    ],
  },
  // 开发环境
  mode: 'production',
};

loaders/replace-loader.js


const loaderUtils = require('loader-utils');
module.exports = function (source) {
  // 获取参数
  let options = loaderUtils.getOptions(this);
  for (let [key, value] of Object.entries(options)) {
    source = source.replace(`{{${key}}}`, value);
  }
  return source;
};

src/index.js


console.log('hi {{name}}');

指定打包命令


$ npm run build

dist/index.js


console.log("hi Tom");

参考

相关文章
|
10月前
|
JSON 前端开发 JavaScript
浅谈一下 webpack 以及 loader 和 plugin
浅谈一下 webpack 以及 loader 和 plugin
133 0
|
3月前
|
Web App开发 JSON 前端开发
Webpack【搭建Webpack环境、Webpack增加配置文件、Webpack中使用Loader、Webpack分离CSS文件 】(一)-全面详解(学习总结---从入门到深化)
Webpack【搭建Webpack环境、Webpack增加配置文件、Webpack中使用Loader、Webpack分离CSS文件 】(一)-全面详解(学习总结---从入门到深化)
56 0
|
4月前
|
JSON 前端开发 JavaScript
Webpack【搭建Webpack环境、Webpack增加配置文件、Webpack中使用Loader、Webpack分离CSS文件 】(一)-全面详解(学习总结---从入门到深化)(上)
Webpack【搭建Webpack环境、Webpack增加配置文件、Webpack中使用Loader、Webpack分离CSS文件 】(一)-全面详解(学习总结---从入门到深化)
58 0
|
4月前
|
前端开发 JavaScript
webpack 核心武器:loader 和 plugin 的使用指南(下)
webpack 核心武器:loader 和 plugin 的使用指南(下)
webpack 核心武器:loader 和 plugin 的使用指南(下)
|
4月前
|
JSON 前端开发 JavaScript
webpack 核心武器:loader 和 plugin 的使用指南(上)
webpack 核心武器:loader 和 plugin 的使用指南(上)
webpack 核心武器:loader 和 plugin 的使用指南(上)
|
4月前
|
XML JSON 前端开发
说说webpack中常见的loader?解决了什么问题?
在Webpack中,Loader是用于处理各种文件类型的模块加载器,它们用于对文件进行转换、处理和加载。常见的Loader解决了以下问题:
23 0
|
4月前
|
Web App开发 前端开发 JavaScript
Webpack【搭建Webpack环境、Webpack增加配置文件、Webpack中使用Loader、Webpack分离CSS文件 】(一)-全面详解(学习总结---从入门到深化)(下)
Webpack【搭建Webpack环境、Webpack增加配置文件、Webpack中使用Loader、Webpack分离CSS文件 】(一)-全面详解(学习总结---从入门到深化)
29 0
|
9月前
|
前端开发 JavaScript Shell
Webpack中常见的Loader?解决了什么问题?
Webpack中常见的Loader?解决了什么问题?
62 0
|
9月前
|
缓存 前端开发 API
如何实现一个Webpack Loader
如何实现一个Webpack Loader
60 0
|
5月前
|
JSON 数据格式
《Webpack5 核心原理与应用实践》学习笔记-> loader配置效验与内置工具
《Webpack5 核心原理与应用实践》学习笔记-> loader配置效验与内置工具
34 0