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",
]
},
}
}
}