1 Star 0 Fork 3

邓岳春/vue3基础版项目

forked from jybjy/vue3基础版项目 
加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
vue.config.js 3.98 KB
一键复制 编辑 原始数据 按行查看 历史
DESKTOP-SNN21VV\qbaozh 提交于 2021-01-07 10:08 . 初始版本1
// 代码压缩
const UglifyJsPlugin = require('uglifyjs-webpack-plugin')
// gzip压缩
const CompressionWebpackPlugin = require('compression-webpack-plugin')
// 是否为生产环境
const isProduction = process.env.NODE_ENV !== 'development'
// 本地环境是否需要使用cdn; 值对应 true / false
const devNeedCdn = true
// cdn链接
// 插件或者框架具体cdn链接,可去官网查找,一般都会有对应的cdn链接地址;
// 项目资源 如打包后的静态资源(改变不频繁) css, js, img 等资源 可上传到公司cdn服务器;在把对应的链接写入css 即可
const cdn = {
// cdn:模块名称和模块作用域命名(对应window里面挂载的变量名称)
externals: {
// vue: 'vue 官方cdn链接',
// vuex: 'Vuex 官方cdn链接',
// 'vue-router': 'VueRouter 官方cdn链接'
},
// cdn的css链接
css: [],
// cdn的js链接
js: []
}
module.exports = {
productionSourceMap: false,
lintOnSave: false, //禁用eslint代码检测
devServer: {
port: 8088, // 端口号
host: '0.0.0.0',
hotOnly: false,
https: false, // https:{type:Boolean}
open: false, //配置自动启动浏览器
// 可配置多个代理 proxy: 'http://localhost:4000' // 配置跨域处理,只有一个代理
proxy: {
'/api1': {
target: '<url1>',
ws: true,
changeOrigin: true
},
'/api2': {
target: '<url2>'
}
}
},
chainWebpack: config => {
// ============压缩图片 start============
config.module
.rule('images')
.use('image-webpack-loader')
.loader('image-webpack-loader')
.options({ bypassOnDebug: true })
.end()
// ============注入cdn start============
config.plugin('html').tap(args => {
// 生产环境或本地需要cdn时,才注入cdn
if (isProduction || devNeedCdn) args[0].cdn = cdn
return args
})
},
configureWebpack: config => {
// 用cdn方式引入,则构建时要忽略相关资源
if (isProduction || devNeedCdn) config.externals = cdn.externals
// 生产环境相关配置
if (isProduction) {
// 代码压缩
config.plugins.push(
new UglifyJsPlugin({
uglifyOptions: {
//生产环境自动删除console
compress: {
warnings: false, // 若打包错误,则注释这行
drop_debugger: true,
drop_console: true,
pure_funcs: ['console.log']
}
},
sourceMap: false,
parallel: true
})
)
// gzip压缩
const productionGzipExtensions = ['html', 'js', 'css']
config.plugins.push(
new CompressionWebpackPlugin({
filename: '[path].gz[query]',
algorithm: 'gzip',
test: new RegExp(
'\\.(' + productionGzipExtensions.join('|') + ')$'
),
threshold: 10240, // 只有大小大于该值的资源会被处理 10240
minRatio: 0.8, // 只有压缩率小于这个值的资源才会被处理
deleteOriginalAssets: false // 删除原文件
})
)
// 公共代码抽离
config.optimization = {
splitChunks: {
cacheGroups: {
vendor: {
chunks: 'all',
test: /node_modules/,
name: 'vendor',
minChunks: 1,
maxInitialRequests: 5,
minSize: 0,
priority: 100
},
common: {
chunks: 'all',
test: /[\\/]src[\\/]js[\\/]/,
name: 'common',
minChunks: 2,
maxInitialRequests: 5,
minSize: 0,
priority: 60
},
styles: {
name: 'styles',
test: /\.(sa|sc|c)ss$/,
chunks: 'all',
enforce: true
},
runtimeChunk: {
name: 'manifest'
}
}
}
}
}
}
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
TypeScript
1
https://gitee.com/dengyuechun/vue3-basic-project.git
git@gitee.com:dengyuechun/vue3-basic-project.git
dengyuechun
vue3-basic-project
vue3基础版项目
master

搜索帮助

0d507c66 1850385 C8b1a773 1850385