vue-cli中设置webpack系列文章七 ------ webpack.prod.conf.js

webpack.prod.conf.js

  var path = require('path')
  var utils = require('./utils')
  var webpack = require('webpack')
  var config = require('../config')
  var merge = require('webpack-merge')
  var baseWebpackConfig = require('./webpack.base.conf')
  var CopyWebpackPlugin = require('copy-webpack-plugin')
  var HtmlWebpackPlugin = require('html-webpack-plugin')
  var ExtractTextPlugin = require('extract-text-webpack-plugin')
  var OptimizeCSSPlugin = require('optimize-css-assets-webpack-plugin')
  // 猎取当前环境
  var env = config.build.env
  var webpackConfig = merge(baseWebpackConfig, {
    module: {
      // 将.vue外部的css或css预处置惩罚器文件举行处置惩罚
      rules: utils.styleLoaders({
        sourceMap: config.build.productionSourceMap,
        extract: true
      })
    },
    // 是不是开启调试
    devtool: config.build.productionSourceMap ? '#source-map' : false,
    output: {
      path: config.build.assetsRoot,
      filename: utils.assetsPath('js/[name].[chunkhash].js'),
      // 定义在非进口文件援用的文件的称号
      chunkFilename: utils.assetsPath('js/[id].[chunkhash].js')
    },
    plugins: [
      // 定义一个在编译时间内能够运用的全局变量,用来封闭vue的一切正告功用
      new webpack.DefinePlugin({
        'process.env': env
      }),
      // 最小化一切JavaScript输出块,消弭无作用的代码
      new webpack.optimize.UglifyJsPlugin({
        compress: {
          warnings: false
        },
        sourceMap: false
      }),
      // ExtractTextPlugin会将一切的「进口 chunk(entry chunks)」中的 require("style.css") 移动到自力星散的css文件。因而,款式不再内联到javascript内里,但会放到一个零丁的css包文件 (styles.css)当中。 假如款式文件较大,这会更快,由于款式文件会跟javascript包并行加载
      new ExtractTextPlugin({
        filename: utils.assetsPath('css/[name].[contenthash].css')
      }),
      // 紧缩提取出来的CSS,而且举行css的复用以处理extract-text-webpack-plugin将css处置惩罚后会涌现的css反复的状况
      new OptimizeCSSPlugin({
        cssProcessorOptions: {
          safe: true
        }
      }),
      // 构建要编译输出的index.html,并在文件中嵌入资本文件
      new HtmlWebpackPlugin({
        // 输出的HTML文件名
        filename: config.build.index,
        // 模板文件途径
        template: 'index.html',
        // 设置为true或body能够将js代码放到<body>元素末了
        // 设置为head将js代码加到<head>内里
        // 设置为false一切静态资本css和JavaScript都不会注入到模板文件中
        inject: true,
        minify: {
          // 删除解释
          removeComments: true,
          // 兼并空缺
          collapseWhitespace: true,
          // 删除属性的引号
          removeAttributeQuotes: true
        },
        // 经由过程CommonsChunkPlugin掌握chunks在html文件中增加的递次  
        // 设置为dependency即根据它们之间的依靠关联增加
        chunksSortMode: 'dependency'
      }),
      // webpack将大众模块打包的vendor.js内里运用CommonsChunkPlugin将vendor.js星散到零丁的文件
      new webpack.optimize.CommonsChunkPlugin({
        // 大众模块名字
        name: 'vendor',
        minChunks: function(module, count) {
          return (
            module.resource &&
            /\.js$/.test(module.resource) &&
            module.resource.indexOf(
              path.join(__dirname, '../node_modules')
            ) === 0
          )
        }
      }),
      // 运用CommonsChunkPlugin能够保证假如我们的第三方插件没有更改,在打包的时刻能够不被从新的打包
      // 待到上线后就不会从新的加载以到达缓存的目标
      // 我们会取得webpack执行时间和输出一份json文件保留chunk的id和终究援用它们的文件印射关联
      new webpack.optimize.CommonsChunkPlugin({
        name: 'manifest',
        chunks: ['vendor']
      }),
      // 复制static文件夹内的静态资本到打包好的文件中
      // 详细的途径是之前我们设置的"config.build.assetsSubDirectory"
      new CopyWebpackPlugin([{
        from: path.resolve(__dirname, '../static'),
        to: config.build.assetsSubDirectory,
        ignore: ['.*']
      }])
    ]
  })
  // 假如开启了Gzip紧缩,运用以下设置
  if (config.build.productionGzip) {
    var CompressionWebpackPlugin = require('compression-webpack-plugin')
    webpackConfig.plugins.push(
      new CompressionWebpackPlugin({
        asset: '[path].gz[query]',
        algorithm: 'gzip',
        test: new RegExp(
          '\\.(' +
          config.build.productionGzipExtensions.join('|') +
          ')$'
        ),
        threshold: 10240,
        minRatio: 0.8
      })
    )
  }
  // 假如开启了编译报告,运用以下设置
  if (config.build.bundleAnalyzerReport) {
    var BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin
    webpackConfig.plugins.push(new BundleAnalyzerPlugin())
  }
  module.exports = webpackConfig
    原文作者:亲爱的阿干
    原文地址: https://segmentfault.com/a/1190000019232004
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞