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

控制台解析了对应的文件

相关推荐
她超甜i2 小时前
前端通过后端给的webrtc的链接,在前端展示,并更新实时状态
前端·javascript·webrtc
歪歪1002 小时前
Redux和MobX在React Native状态管理中的优缺点对比
前端·javascript·react native·react.js·架构·前端框架
东风西巷2 小时前
Atlantis Word Processor:全方位的文字处理专家
前端·学习·word·软件需求
今天不要写bug2 小时前
基于elementUI实现一个可编辑的表格(简洁版)
前端·javascript·elementui
上优2 小时前
Vue3纯前端同源跨窗口通信移动AGV小车
前端·vue.js·状态模式
h_k100863 小时前
Chrome 插件开发入门技术文章大纲
前端·chrome
一只小阿乐3 小时前
vue-router 的实现原理
前端·javascript·vue.js·路由·vue-router
Zz_waiting.3 小时前
案例开发 - 日程管理 - 第七期
开发语言·前端·javascript·vue.js·html·路由
一只小风华~3 小时前
Vue:事件处理机制详解
前端·javascript·vue.js·typescript·前端框架
dy17177 小时前
element-plus表格默认展开有子的数据
前端·javascript·vue.js