webpack自定义loader

loader介绍

在webpack中打包只能解析js文件,对于一些图片、css等资源需要借助loader来进行文件的转码,loader是对模块非js文件进行转换的插件,例如 webpack中css-loader、style-loader、baber-loader;

自定义loader

loader本质上是一个导出为函数的js模块,即函数

  1. 使用webpack 解析 test.txt文件
javascript 复制代码
<script>
  export default {
    a: 1,
    b: 2
  }
</script>
  1. 初始化基于webpack工程安装对应的webpack webpack-cli
  • npm init 初始化项目
  • 创建src/index.js 入口文件
  • 创建public/index.html
  • 创建webpack.config.js,填入配置
  • npm i -D webpack webpack-cli
  • 配置build 命令为 webpack
  • 执行npm run build完成打包构建
  1. webpack.config.js配置
javascript 复制代码
const path = require('path')

module.exports = {
    mode: 'development', // 指定环境
    entry: './src/index.js', // 入口文件
    output: {  // 输出文件
        path: path.resolve(__dirname, './dist'),
        filename: 'bundle.js'
    },
    module: {
        rules: [
          {
                test: /\.imooc$/,
                use: [path.resolve(__dirname, './loader/test-loader.js')]  // 用来解析对应的loader文件
            }
        ]
    }
}
  1. 解析test.txt test-loader.js文件
javascript 复制代码
const REG = /<script>([\s\S]+?)<\/script>/
module.exports = function(source) {
    console.log('== test-loader source', source)
    const __source = source.match(REG)
    console.log(__source)
    return __source && __source[1] ? __source[1] : source
}

// 判断当前模块是否为主模块,如果为主模块,则运行以下代码
// 用来对loader进行单独测试
if(require.main === module) {
    const source = `
      <script>
        export default {
            a: 1,
            b: 2
        }
        </script>
    `
    const match = source.match(REG)
    console.log(match)

    console.log(' '.match(/\s/))
}

最后执行npm run build

控制台解析了对应的文件

相关推荐
良逍Ai出海6 分钟前
免费模板搭完独立站后,我用 Codex + Figma 做了自己的页面设计
前端·人工智能·figma
纽格立科技10 分钟前
DRM 发射端链路图(下)
前端·人工智能·车载系统·信息与通信·传媒
代码小库13 分钟前
【2026前端转 AI 全栈指南】第 2 章(下):NestJS 项目创建 · MongoDB 配置 · 项目启动与调试
前端·数据库·mongodb
之歆22 分钟前
Promise 基础技术深度解析:从回调地狱到链式调用
前端·okhttp·promise
甲维斯24 分钟前
国产版“Codex”初体验,智谱ZCode很强啊!
前端·人工智能·ai编程
道友可好26 分钟前
AI 怎么自己跑完一个 6 小时的任务?
前端·人工智能·后端
To_OC39 分钟前
通义千问多模态生图踩坑记:我是如何把两个报错逐个干翻的
前端·aigc·vite
Bigfish_coding43 分钟前
前端转agent-第一周【python】-02 FastAPI与Pydantic实战(TS/JS视角)
前端
秃头网友小李44 分钟前
前端难点:Vue3 响应式遇上 Three.js / ECharts —— 为什么要用 shallowRef?
前端·vue.js
梦曦i1 小时前
Vite插件开发框架:14个实用插件与完整工具包
前端