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");

参考

面试官:请实现一个Sass-Loader

相关文章
|
人工智能 监控 算法
水泥行业解决方案
阿里云水泥解决方案将着重与能耗、质量、设备三大核心领域,运用大数 据分析技术,结合水泥业务实际需求,通过提升生产效率、预测产品质 量、设备状态检测等方案,对水泥生产进行全局优化,帮助水泥行业降本 增效,提质优产。
水泥行业解决方案
|
存储 算法 Linux
opencv-python 最新4.6.0.66版安装及介绍翻译
opencv-python 最新4.6.0.66版安装及介绍翻译
3756 0
|
6天前
|
人工智能 运维 安全
|
4天前
|
人工智能 异构计算
敬请锁定《C位面对面》,洞察通用计算如何在AI时代持续赋能企业创新,助力业务发展!
敬请锁定《C位面对面》,洞察通用计算如何在AI时代持续赋能企业创新,助力业务发展!
|
5天前
|
机器学习/深度学习 人工智能 自然语言处理
B站开源IndexTTS2,用极致表现力颠覆听觉体验
在语音合成技术不断演进的背景下,早期版本的IndexTTS虽然在多场景应用中展现出良好的表现,但在情感表达的细腻度与时长控制的精准性方面仍存在提升空间。为了解决这些问题,并进一步推动零样本语音合成在实际场景中的落地能力,B站语音团队对模型架构与训练策略进行了深度优化,推出了全新一代语音合成模型——IndexTTS2 。
532 14
|
11天前
|
人工智能 JavaScript 测试技术
Qwen3-Coder入门教程|10分钟搞定安装配置
Qwen3-Coder 挑战赛简介:无论你是编程小白还是办公达人,都能通过本教程快速上手 Qwen-Code CLI,利用 AI 轻松实现代码编写、文档处理等任务。内容涵盖 API 配置、CLI 安装及多种实用案例,助你提升效率,体验智能编码的乐趣。
897 109
|
5天前
|
人工智能 测试技术 API
智能体(AI Agent)搭建全攻略:从概念到实践的终极指南
在人工智能浪潮中,智能体(AI Agent)正成为变革性技术。它们具备自主决策、环境感知、任务执行等能力,广泛应用于日常任务与商业流程。本文详解智能体概念、架构及七步搭建指南,助你打造专属智能体,迎接智能自动化新时代。