vue-cli 3.0脚手架配置及扩展 (二):vue.config.js多页配置

vue-cli 3.0官方支持多页,重点在于vue.config.js文件的配置

其中baseUrl和pages数据为VueConf基础类产生,VueConf类接受process.argv作为默认参数

process.argv为bash窗口中我们输入的npm run * 命令,VueConf类对命令进行了再次包装,类文件后面文章放出


    《vue-cli 3.0脚手架配置及扩展 (一):扩展说明》

    《vue-cli 3.0脚手架配置及扩展 (二):vue.config.js多页配置》

    《vue-cli 3.0脚手架配置及扩展 (三):config.app.js应用目录配置》

    《vue-cli 3.0脚手架配置及扩展 (四):VueConf类》

    《vue-cli 3.0脚手架配置及扩展 (五):AppConf类》


/**
 * @fileOverview app配置
 * @author Franks.T.D
 * @date 2018/06/17
 */

const path = require('path')
const debug = process.env.NODE_ENV !== 'production'
const VueConf = require('./src/assets/js/libs/vue_config_class')
const vueConf = new VueConf(process.argv)

console.log('')
console.log('本地启动或构建的文件信息 | 开始--------------------------------------------------------------')
console.log(vueConf.pages)
console.log('本地启动或构建的文件信息 | 结束--------------------------------------------------------------')
console.log('')

module.exports = {
  baseUrl: vueConf.baseUrl, // 根域上下文目录
  outputDir: 'dist', // 构建输出目录
  assetsDir: 'assets', // 静态资源目录 (js, css, img, fonts)
  pages: vueConf.pages,
  lintOnSave: true, // 是否开启eslint保存检测,有效值:ture | false | 'error'
  runtimeCompiler: true, // 运行时版本是否需要编译
  transpileDependencies: [], // 默认babel-loader忽略mode_modules,这里可增加例外的依赖包名
  productionSourceMap: true, // 是否在构建生产包时生成 sourceMap 文件,false将提高构建速度
  configureWebpack: config => { // webpack配置,值位对象时会合并配置,为方法时会改写配置
    if (debug) { // 开发环境配置
      config.devtool = 'cheap-module-eval-source-map'
    } else { // 生产环境配置
    }
    Object.assign(config, { // 开发生产共同配置
      resolve: {
        alias: {
          '@': path.resolve(__dirname, './src'),
          '@c': path.resolve(__dirname, './src/components'),
          'vue$': 'vue/dist/vue.esm.js'
        }
      }
    })
  },
  chainWebpack: config => { // webpack链接API,用于生成和修改webapck配置,https://github.com/vuejs/vue-cli/blob/dev/docs/webpack.md
    if (debug) {
      // 本地开发配置
    } else {
      // 生产开发配置
    }
  },
  css: { // 配置高于chainWebpack中关于css loader的配置
    modules: true, // 是否开启支持‘foo.module.css’样式
    extract: true, // 是否使用css分离插件 ExtractTextPlugin,采用独立样式文件载入,不采用