Bootstrap

vue.config.js详解

vue.config.js 是一个可选的配置文件,如果项目的 (和 package.json 同级的) 根目录中存在这个文件,那么它会被 @vue/cli-service 自动加载。

配置项详情见   配置参考 | Vue CLI

'use strict'
// import proxy from './proxy.config.js'
const proxy = require('./src/proxy.config.js')
const path = require('path')
const defaultSettings = require('./src/settings.js')
const CompressionWebpackPlugin = require('compression-webpack-plugin')
// const WebpackBundleAnalyzer = require('webpack-bundle-analyzer').BundleAnalyzerPlugin

function resolve(dir) {
  return path.join(__dirname, dir)
}

const name = defaultSettings.title || 'vue Element Admin' // page title

// If your port is set to 80,
// use administrator privileges to execute the command line.
// For example, Mac: sudo npm run
// You can change the port by the following method:
// port = 9527 npm run dev OR npm run dev --port = 9527
const port = process.env.port || process.env.npm_config_port || 9527 // dev port

// All configuration item explanations can be find in https://cli.vuejs.org/config/
module.exports = {
  /**
   * You will need to set publicPath if you plan to deploy your site under a sub path,
   * for example GitHub Pages. If you plan to deploy your site to https://foo.github.io/bar/,
   * then publicPath should be set to "/bar/".
   * In most cases please use '/' !!!
   * Detail: https://cli.vuejs.org/config/#publicpath
   */
  publicPath: '/',
  outputDir: 'dist',
  assetsDir: 'static',
  // lintOnSave: process.env.VUE_APP_ENV === 'development',  // 太多警告没解决,lint会造成serve热更新时间过长
  lintOnSave: false,
  productionSourceMap: false,
  devServer: {
    port: port,
    open: true,
    overlay: {
      warnings: false,
      errors: true
    },
    proxy: proxy
  },
  // configureWebpack: {
  //   plugins: [
  //     new CompressionWebpackPlugin({
  //       filename: '[path].gzip[query]',   // 提示[email protected]的话filename改为asset
  //       algorithm: 'gzip',
  //       test: new RegExp('\\.(' + productionGzipExtensions.join('|') + ')$'),
  //       threshold: 10240, //内容超过10KB进行压缩
  //       minRatio: 0.8
  //     }),
  //     new BundleAnalyzerPlugin()
  //   ],
  //   name,
  //   resolve: {
  //     alias: {
  //       '@': resolve('src')
  //     }
  //   }
  // },
  configureWebpack: config => {
    return {
      // plugins: [
      //     new CompressionWebpackPlugin({
      //         // asset: '[path].gz[query]',
      //         filename: '[path].gz[query]',
      //         algorithm: 'gzip',
      //         test: /\.(js|css|json|txt|html|ico|svg)(\?.*)?$/i,
      //         threshold: 2048,
      //         minRatio: 0.8
      //     }),
      //     new WebpackBundleAnalyzer()
      // ],
      name,
      resolve: {
        alias: {
          '@': resolve('src')
        }
      },
      externals: {
        'echarts': 'echarts',
        // 'axios': 'axios',
        'vue-clipboard2': 'VueClipboard',
        'moment': 'moment'
      }
    }
  },
  transpileDependencies: [
    'hui',
    /@hui-pro/
  ],
  chainWebpack(config) {
    config.plugins.delete('preload') // TODO: need test
    config.plugins.delete('prefetch') // TODO: need test

    // set svg-sprite-loader
    config.module
      .rule('svg')
      .exclude.add(resolve('src/icons'))
      .end()
    config.module
      .rule('icons')
      .test(/\.svg$/)
      .include.add(resolve('src/icons'))
      .end()
      .use('svg-sprite-loader')
      .loader('svg-sprite-loader')
      .options({
        symbolId: 'icon-[name]'
      })
      .end()

    // set preserveWhitespace
    config.module
      .rule('vue')
      .exclude.add(resolve('src/example'))
      .end()
      .use('vue-loader')
      .loader('vue-loader')
      .tap(options => {
        options.compilerOptions.preserveWhitespace = true
        return options
      })
      .end()

    config.output.filename('[name].[hash].js').end()

    config
      // https://webpack.js.org/configuration/devtool/#development
      .when(process.env.VUE_APP_ENV === 'development',
        config => config.devtool('cheap-source-map')
      )

    config.plugin('compressionPlugin').use(new CompressionWebpackPlugin({
      test: /\.js$|\.html$|.\css/, // 匹配文件名
      threshold: 10240, // 对超过10k的数据压缩
      deleteOriginalAssets: false // 不删除源文件
    }))

    config
      .when(process.env.VUE_APP_ENV !== 'development',
        config => {
          config
            .plugin('ScriptExtHtmlWebpackPlugin')
            .after('html')
            .use('script-ext-html-webpack-plugin', [{
              // `runtime` must same as runtimeChunk name. default is `runtime`
              inline: /runtime\..*\.js$/
            }])
            .end()
          config
            .optimization.splitChunks({
              chunks: 'all',
              maxSize: 1000 * 1024, // 200kb,尝试将大于200kb的文件拆分成n个200kb的文件
              // automaticNameDelimiter: '_',
              cacheGroups: {
                libs: {
                  name: 'chunk-libs',
                  test: /[\\/]node_modules[\\/]/,
                  priority: 10,
                  chunks: 'initial' // only package third parties that are initially dependent
                },
                commons: {
                  name: 'chunk-commons',
                  test: resolve('src/components'), // can customize your rules
                  minChunks: 3, //  minimum common number
                  priority: 5,
                  reuseExistingChunk: true
                }
              }
            })
          config.optimization.runtimeChunk('single')
        }
      )
  }
}

1.'use strict' //声明为严格模式,不能使用未声明的变量

2.const path = require("path") //引入node.js工具模块path,用来处理文件路径的小工具

3.function resolve(dir) {return path.join(__dirname, dir)}  //获取dir的绝对路径

4.const port = process.env.port || process.env.npm_config_port || 9527   //赋值port:如果当前环境端口存在则为当前环境端口,否则找process.env.npm_config_port这个属性,还没有则赋值9527

5.module.exports //commonJS的模块化 注意与ES6模块化的区别

6.publicPath: '/', //部署应用包时的基本 URL

7.outputDir: 'dist', //输出文件目录,当运行 vue-cli-service build 时生成的生产环境构建文件的目录。注意目标目录在构建之前会被清除 (构建时传入 --no-clean 可关闭该行为)。

8.assetsDir: 'static', //放置生成的静态资源 (js、css、img、fonts) 的目录。

9.lintOnSave: false, //是否在保存的时候使用 `eslint-loader` 进行检查,有效的值:`ture` | `false` | `"error"`  当设置为 `"error"` 时,检查出的错误会触发编译失败。

10.productionSourceMap: false, //如果你不需要生产环境的 source map,可以将其设置为 false 以加速生产环境构建。

11.devServer中的proxy // 代理

12.configureWebpack //webpack配置项,详情见 Working with Webpack | Vue CLI

13.transpileDependencies //默认情况下 babel-loader 会忽略所有 node_modules 中的文件。你可以启用本选项,以避免构建后的代码中出现未转译的第三方依赖。

不过,对所有的依赖都进行转译可能会降低构建速度。如果对构建性能有所顾虑,你可以只转译部分特定的依赖:给本选项传一个数组,列出需要转译的第三方包包名或正则表达式即可。

;