webpack.config.js(webpack相关配置介绍)

const path = require('path');
//引入webpack
const webpack = require('webpack');
//清除build/dist文件夹文件
const CleanWebpackPlugin = require('clean-webpack-plugin');
//生成创建Html入口文件
const HtmlWebpackPlugin = require('html-webpack-plugin');
//将css提取到单独的文件中
const MiniCssExtract = require('mini-css-extract-plugin');
//区分大小写的路径
const CaseSensitivePathsPlugin = require('case-sensitive-paths-webpack-plugin');
//在webpack中拷贝文件和文件夹(在离线应用中,前端所有文件都需在在本地,有些文件(比如iconFont)需要转为离线文件,
//这些文件可以直接引用更方便些,这就需要在打包时直接复制到打包文件下,可以在打包时调用文件复制方法)
const CopyPlugin = require('copy-webpack-plugin');
//将选择的chunk插入到html中(要与html-webpack-plugin配合使用)
const InlineChunkHtmlPlugin = require('./plugins/InlineChunkHtmlPlugin');
module.exports = function exports(webpackEnv) {
// 定义生产环境or开发环境
  const isEnvDevelopment = webpackEnv === 'development';
  const isEnvProduction = webpackEnv === 'production';
  return {
    mode: isEnvProduction ? 'production' : isEnvDevelopment && 'development',   //开发模式
    bail: isEnvProduction,    // 生产环境时,如果编译过程一有error,立马停止编译
    devtool: isEnvProduction
      ? false
      : isEnvDevelopment && 'cheap-module-source-map',
    // 入口文件
    entry: { main: './src/main.js' },
    output: {
      //输出文件路径
      path: path.resolve(__dirname, '../dist'),
      pathinfo: isEnvDevelopment,
      //输出文件名
      filename: isEnvProduction
        ? 'assets/js/[name].[contenthash:8].js'
        : isEnvDevelopment && 'assets/js/bundle.js',
      futureEmitAssets: true,
      chunkFilename: isEnvProduction
        ? 'assets/js/[name].[contenthash:8].chunk.js'
        : isEnvDevelopment && 'assets/js/[name].chunk.js',
      publicPath: '/',
      globalObject: 'this',
    },
//  生产环境中压缩文件的一些配置
optimization: {
      minimize: isEnvProduction,
      splitChunks: {
        chunks: 'all',
        name: false,
       // 缓存
        cacheGroups: {
          libs: {
            name: 'chunk-libs',
            test: /[\\/]node_modules[\\/]/,
            priority: 10,
            chunks: 'initial', // only package third parties that are initially dependent
          },
          elementUI: {
            name: 'chunk-elementUI', // split elementUI into a single package
            priority: 20,
            test: /[\\/]node_modules[\\/]_?element-ui(.*)/, // in order to adapt to cnpm
          },
          commons: {
            name: 'chunk-commons',
            test: path.join(__dirname, 'src/components'), // can customize your rules
            minChunks: 3, //  minimum common number
            priority: 5,
            reuseExistingChunk: true,
          },
        },
      },
      runtimeChunk: {
        name: (entrypoint) => `runtime-${entrypoint.name}`,
      },
    },
resolve: {
      // 只在当前目录下查找
      modules: ['node_modules'],
     //扩展名顺序
      extensions: [
        '.js',
        '.jsx',
        '.tsx',
        '.ts',
        '.css',
        '.scss',
        '.less',
        '.vue',
        ...
      ],
      //别名
      alias: {
        '@': path.resolve(__dirname, '../src'),
        '@api': path.resolve(__dirname, '../src/api'),
        '@assets': path.resolve(__dirname, '../src/assets'),
        '@utils': path.resolve(__dirname, '../src/utils'),
       ...
      },
    },
// loader加载器模块配置
module: {
      strictExportPresence: true,
      rules: [
        { parser: { requireEnsure: false } },
        { 
          test: /\.(js|mjs|jsx|ts|tsx)$/,   //正则表达式匹配.js巴拉巴拉为后缀的文件
          enforce: 'pre',   //强制更改顺序,pre 前  post 后
         // 使用loader
          use: [
            {
              options: {
                cache: true,
                eslintPath: require.resolve('eslint'),
                resolvePluginsRelativeTo: __dirname,
              },
              loader: require.resolve('eslint-loader'),
            },
          ],
          include: path.resolve(__dirname, '../src'),
        },
     ],
},
//  配置插件
plugins: [
      isEnvProduction && new CleanWebpackPlugin(),
      new CopyPlugin({
        patterns: [
          { from: 'static', to: path.resolve(__dirname, '../dist/static') },
        ],
      }),
      report ? new BundleAnalyzerPlugin({}) : undefined,
      new VueLoaderPlugin(),
      new HtmlWebpackPlugin({
        inject: true,
        template: './src/index.html',    //模板路径,指定生成的文件所依赖哪一个html文件模板(需安装对应的loader)
        ...(isEnvProduction
          ? {
            minify: {    //传递 html-minifier 选项给 minify 输出
              removeComments: true,    //清理html中的注释
              collapseWhitespace: true,  //清理html中的空格、换行符
              removeRedundantAttributes: true,  //清理属性上的引号
              useShortDoctype: true,  //用short (HTML5) doctype替换doctype
              removeEmptyAttributes: true,  //清理内容为空的元素
              removeStyleLinkTypeAttributes: true,  //从style和link标签中删除type="text/css"
              keepClosingSlash: true,  //保留单例元素的末尾斜杠
              minifyJS: true,  //压缩html内的js
              minifyCSS: true,  //压缩html内的样式
              minifyURLs: true,  //在各种属性中缩小url(使用relateurl)
            },
          }
          : undefined),
      }),
...
    ].filter(Boolean),
  };
};
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,723评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,003评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,512评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,825评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,874评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,841评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,812评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,582评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,033评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,309评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,450评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,158评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,789评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,409评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,609评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,440评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,357评论 2 352

推荐阅读更多精彩内容