vue-config的使用

2021-12-13  本文已影响0人  萤火kin

vue-config的使用

参考

配置


'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/view-design@4.5.0/dist/styles/iview.css'
                ],
                js: [
                    "https://cdn.jsdelivr.net/npm/vue@2.5.10/dist/vue.min.js",
                    "https://cdn.jsdelivr.net/npm/vue-router@3.0.1/dist/vue-router.min.js",
                    "https://cdn.jsdelivr.net/npm/view-design@4.5.0/dist/iview.min.js",
                    "https://cdn.jsdelivr.net/npm/vue-i18n@7.8.0/dist/vue-i18n.min.js",
                    "https://cdn.jsdelivr.net/npm/axios@0.18.0/dist/axios.min.js",
                    "https://cdn.jsdelivr.net/npm/vuex@3.0.1/dist/vuex.min.js",
                    "https://cdn.jsdelivr.net/npm/echarts@4.0.4/dist/echarts.min.js",
                    "https://cdn.jsdelivr.net/npm/view-design@4.5.0/dist/locale/en-US.js",
                    "https://cdn.jsdelivr.net/npm/view-design@4.5.0/dist/locale/zh-TW.js",
                    "https://cdn.jsdelivr.net/npm/view-design@4.5.0/dist/locale/zh-CN.js",
                    "https://cdn.jsdelivr.net/npm/js-cookie@2.2.0/src/js.cookie.min.js",
                    "https://cdn.jsdelivr.net/npm/accounting-js@1.1.1/dist/accounting.umd.min.js",
                    "https://cdn.jsdelivr.net/npm/dayjs@1.7.7/dayjs.min.js",
                ]
            },
        }
    }
}

上一篇 下一篇

猜你喜欢

热点阅读