zoukankan      html  css  js  c++  java
  • webpack之主要部分Entry、Output、Loaders、Plugins说明

    简述

    webpack的主要组成部分,Entry、Output、Loaders、Plugins

    Entry(入口)

    webpack开始解析关联资源的入口文件

    • 单个入口可以直接使用字符串
    • 多个入口可以使用对象进行设置
    • 使用字符串配置时,默认chunkName(key)为main
    // 单个入口
    const config = {
      entry: './path/to/my/entry/file.js'
    };
    

    // 多个入口
    const config = {
    entry: {
    main: './path/to/my/entry/file.js',
    app: './path/to/my/entry/file.js'
    }
    };

    Output(输出)

    webpack打包完成后的输出配置,包括文件命名、文件生成路径、chunkName命名等

    const config = {
      output: {
        filename: 'bundle.js', // 生成的默认打包文件名
        path: '/home/proj/public/assets' // 生成的默认打包文件路径
      }
    };
    

    Loaders(加载器、更喜欢叫解析器)

    webpack打包完成后只有css、html、js和一些资源文件,所以需要不用的解析器进行转化

    • 每个rules的解析顺序是从下到上执行的,顺序不可以颠倒,否则会报错
    • 每个解析器都需要手动安装(按需添加)
    module.exports = {
      
    module: {
        rules: [
          {
            test: /.css$/, // 匹配文件
            use: [
              { loader: 'style-loader'},
              {
                loader: 'css-loader', // 配置使用的解析器
                options: { // 解析器的参数配置
                  modules: true
                }
              }
            ]
          }
        ]
      }
    };
    

    Plugins(插件)

    应该是webpack的支柱功能,目的在于解决其它配置无法实现的事情

    module.exports = {
      
    module: {
        plugins: [
            new HtmlWebpackPlugin({template: './src/index.html'}) // 生成html模板 template:使用的自己的模板
        ]
      }
    };
    
  • 相关阅读:
    Jvm年轻代复制到Survivor To区时,对象存放不下会发生什么?
    Jvm内存布局和Java对象内存布局
    ArrayList的removeIf和iterator.remove性能比较
    闲着没事做,用js做了一个冒泡排序的动画
    对象与this
    idea 简记
    线程按序交替
    大数阶乘
    序列化 与 反序列化
    人月神话
  • 原文地址:https://www.cnblogs.com/xpengp/p/13368360.html
Copyright © 2011-2022 走看看