vue-config的使用

vue-config的使用

参考

  • https://cli.vuejs.org/zh/config/#vue-config-js
  • https://www.jianshu.com/p/b358a91bdf2d

配置

  • publicPath:部署生产环境和开发环境下的URL
  • outputDir:build 时 ,生成文件的目录名称
  • assetsDir:用于放置生成的静态资源
  • lintOnSave:是否开启eslint保存检测
  • productionSourceMap:设为false打包时不生成.map文件,如果你不需要生产环境的 source map,可以将其设置为 false 以加速生产环境构建。
  • devServer:代理配置等
  • chainWebpack:config.resolve.alias路径别名配置

  • webpack(打包)

  • webpack-cli(解析参数)

  • webpack-dev-server(webpack开发环境)

  • vue-loader(解析.vue文件),需要配合plugins: [new VueLoaderPlugin()]插件使用

  • vue-style-loader(支持服务端渲染)

  • vue-template-compiler(解析template标签)

  • css-loader(处理css)

  • @babel/core(babel核心模块)

  • @babel/preset-env(高级语法转换成低级语法,ES6-ES5)

  • babel-loader(解析js文件)

  • html-webpack-plugin(打包html插入到页面中)

  • webpack-merge(webpack合并文件)

  • presets插件集合

  • plugins插件:VueLoaderPlugin(配合vue-loader使用),HtmlwebpackPlugin(会把打包后的文件自动插到对应的文件中,如public/index.html)

  • Compiler 模块是 webpack 的支柱引擎,它通过 CLI 或 Node API 传递的所有选项,创建出一个 compilation 实例。它扩展(extend)自 Tapable 类,以便注册和调用插件。大多数面向用户的插件会首先在 Compiler 上注册。

'use strict'
const path = require('path')

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

const name = process.env.VUE_APP_TITLE || 'Aggrepay管理系统' // 网页标题

const port = process.env.port || process.env.npm_config_port || 80 // 端口

// vue.config.js 配置说明
//官方vue.config.js 参考文档 https://cli.vuejs.org/zh/config/#css-loaderoptions
// 这里只列一部分,具体配置参考文档
module.exports = {
  // 部署生产环境和开发环境下的URL。
  // 默认情况下,Vue CLI 会假设你的应用是被部署在一个域名的根路径上
  // 例如 https://www.aggrepay.vip/。如果应用被部署在一个子路径上,你就需要用这个选项指定这个子路径。例如,如果你的应用被部署在 https://www.aggrepay.vip/admin/,则设置 baseUrl 为 /admin/。
  publicPath: process.env.NODE_ENV === "production" ? "/" : "/",
  // 在npm run build 或 yarn build 时 ,生成文件的目录名称(要和baseUrl的生产环境路径一致)(默认dist)
  outputDir: 'dist',
  // 用于放置生成的静态资源 (js、css、img、fonts) 的;(项目打包之后,静态资源会放在这个文件夹下)
  assetsDir: 'static',
  // 是否开启eslint保存检测,有效值:ture | false | 'error'
  lintOnSave: process.env.NODE_ENV === 'development',
  // 如果你不需要生产环境的 source map,可以将其设置为 false 以加速生产环境构建。// 设为false打包时不生成.map文件
  productionSourceMap: false,
  // webpack-dev-server 相关配置
  devServer: {
    host: '0.0.0.0',
    port: port,  // 端口号
    open: true,  // 自动打开浏览器
    proxy: {
      // detail: https://cli.vuejs.org/config/#devserver-proxy
      [process.env.VUE_APP_BASE_API]: {
        // target: 'http://172.18.21.204:8080',
        // target: 'http://172.18.21.105:8080',
        // target: `http://172.18.20.214:8080`,
        target: `http://aggrepay.yeahpay.in:80`,
        changeOrigin: true,
        pathRewrite: {
          ['^' + process.env.VUE_APP_BASE_API]: process.env.VUE_APP_BASE_API
        }
      }
    },
    disableHostCheck: true
  },

  //-----------------------------
  // 文件夹路径简写(别名配置)
  configureWebpack: {
    name: name,
    resolve: {
      alias: {
        '@': resolve('src')
      }
    }
  },

  chainWebpack: config => {
        config.resolve.alias
            .set('@', resolve('src')) // key,value自行定义,比如.set('@@', resolve('src/components'))
            .set('_c', resolve('src/components'));
        config.module
            .rule('vue')
            .use('iview')
            .loader('iview-loader')
            .options({ prefix: false });
    },
  
  //------------------------------------

  //  cdn优化
    configureWebpack: {
        // 打包忽略文件
        externals: {
            "vue": "Vue",
            "view-design": "iview",
            "vue-router": "VueRouter",
            "axios": "axios",
            "vue-i18n": "vue-i18n",
            "vuex": "Vuex",
            "echarts": "echarts",
            "js-cookie": "Cookies",
            "accounting-js": "accounting",
            "dayjs": "dayjs",
        }
    },
    pages: {
        index: {
            entry: 'src/main.js',
            template: 'public/index.html',
            filename: 'index.html',
            chunks: ['chunk-vendors', 'chunk-common', 'index'],
            cdn: {
                css: [
                    'https://cdn.jsdelivr.net/npm/[email protected]/dist/styles/iview.css'
                ],
                js: [
                    "https://cdn.jsdelivr.net/npm/[email protected]/dist/vue.min.js",
                    "https://cdn.jsdelivr.net/npm/[email protected]/dist/vue-router.min.js",
                    "https://cdn.jsdelivr.net/npm/[email protected]/dist/iview.min.js",
                    "https://cdn.jsdelivr.net/npm/[email protected]/dist/vue-i18n.min.js",
                    "https://cdn.jsdelivr.net/npm/[email protected]/dist/axios.min.js",
                    "https://cdn.jsdelivr.net/npm/[email protected]/dist/vuex.min.js",
                    "https://cdn.jsdelivr.net/npm/[email protected]/dist/echarts.min.js",
                    "https://cdn.jsdelivr.net/npm/[email protected]/dist/locale/en-US.js",
                    "https://cdn.jsdelivr.net/npm/[email protected]/dist/locale/zh-TW.js",
                    "https://cdn.jsdelivr.net/npm/[email protected]/dist/locale/zh-CN.js",
                    "https://cdn.jsdelivr.net/npm/[email protected]/src/js.cookie.min.js",
                    "https://cdn.jsdelivr.net/npm/[email protected]/dist/accounting.umd.min.js",
                    "https://cdn.jsdelivr.net/npm/[email protected]/dayjs.min.js",
                ]
            },
        }
    }
}

你可能感兴趣的:(vue-config的使用)