|
|
const path = require('path')
|
|
|
const CompressionPlugin = require('compression-webpack-plugin')
|
|
|
|
|
|
function resolve(dir) {
|
|
|
return path.join(__dirname, dir)
|
|
|
}
|
|
|
|
|
|
// const isProd = process.env.NODE_ENV === 'production'
|
|
|
// const isProd = true
|
|
|
// const needCdn = isProd
|
|
|
// 'vue-router': 'VueRouter',
|
|
|
// 'ant': 'Antd'
|
|
|
// vue: 'Vue',
|
|
|
|
|
|
|
|
|
// const externals = {
|
|
|
// moment: 'moment'
|
|
|
// }
|
|
|
|
|
|
// cdn 外部扩展,通过 cdn 引入,不会被webpack打包
|
|
|
// const assetsCDN = {
|
|
|
// // cdn的css链接
|
|
|
// css: [
|
|
|
// 'http://cdn.jsdelivr.net/npm/ant-design-vue@1.7.2/dist/antd.min.css'
|
|
|
// ],
|
|
|
// // cdn的js链接
|
|
|
// js: [
|
|
|
// 'http://cdn.jsdelivr.net/npm/moment@2.29.4/moment.min.js',
|
|
|
// 'http://cdn.jsdelivr.net/npm/moment@2.29.4/locale/zh-cn.js',
|
|
|
// 'http://cdn.jsdelivr.net/npm/ant-design-vue@1.7.2/dist/antd.min.js'
|
|
|
// ]
|
|
|
// }
|
|
|
|
|
|
// vue.config.js
|
|
|
module.exports = {
|
|
|
/*
|
|
|
Vue-cli3:
|
|
|
Crashed when using Webpack `import()` #2463
|
|
|
https://github.com/vuejs/vue-cli/issues/2463
|
|
|
*/
|
|
|
|
|
|
pages: {
|
|
|
// // 先配置主页
|
|
|
// login: {
|
|
|
// entry: 'src/loginMain.js',
|
|
|
// template: 'public/login.html',
|
|
|
// title: '用户登录'
|
|
|
// },
|
|
|
// 先配置主页
|
|
|
front: {
|
|
|
entry: 'src/frontMain.js',
|
|
|
template: 'public/frontIndex.html',
|
|
|
title: '前端'
|
|
|
},
|
|
|
// 再配置后台管理页面
|
|
|
index: {
|
|
|
entry: 'src/main.js',
|
|
|
template: 'public/index.html',
|
|
|
title: '后台管理'
|
|
|
}
|
|
|
},
|
|
|
|
|
|
// 如果你不需要生产环境的 source map,可以将其设置为 false 以加速生产环境构建。
|
|
|
productionSourceMap: false,
|
|
|
//打包app时放开该配置
|
|
|
//publicPath:'./',
|
|
|
configureWebpack: config => {
|
|
|
//生产环境取消 console.log
|
|
|
if (process.env.NODE_ENV === 'production') {
|
|
|
config.optimization.minimizer[0].options.terserOptions.compress.drop_console = true
|
|
|
}
|
|
|
// config.externals = needCdn ? assetsCDN.externals : {}
|
|
|
},
|
|
|
|
|
|
chainWebpack: (config) => {
|
|
|
|
|
|
config.plugins.delete('prefetch')
|
|
|
// 移除 preload 插件,避免加载多余的资源
|
|
|
// config.plugins.delete('preload')
|
|
|
|
|
|
config.resolve.alias
|
|
|
.set('@$', resolve('src'))
|
|
|
.set('@api', resolve('src/api'))
|
|
|
.set('@assets', resolve('src/assets'))
|
|
|
.set('@comp', resolve('src/components'))
|
|
|
.set('@views', resolve('src/views'))
|
|
|
|
|
|
|
|
|
if (process.env.use_analyzer) {
|
|
|
config.plugin("webpack-bundle-analyzer").use(require("webpack-bundle-analyzer").BundleAnalyzerPlugin)
|
|
|
}
|
|
|
|
|
|
//生产环境,开启js\css压缩
|
|
|
if (process.env.NODE_ENV === 'production') {
|
|
|
config.plugin('compressionPlugin').use(new CompressionPlugin({
|
|
|
test: /\.(js|css|less)$/, // 匹配文件名
|
|
|
threshold: 10240, // 对超过10k的数据压缩
|
|
|
deleteOriginalAssets: false // 不删除源文件
|
|
|
}))
|
|
|
}
|
|
|
|
|
|
|
|
|
// 开启gzip压缩
|
|
|
// config.plugin('compressionPlugin').use(
|
|
|
// new CompressionPlugin(
|
|
|
// {
|
|
|
// filename: info => {
|
|
|
// return `${info.path}.gz${info.query}`
|
|
|
// },
|
|
|
// algorithm: 'gzip',
|
|
|
// threshold: 10240, // 只有大小大于该值的资源会被处理 10240
|
|
|
// test: new RegExp('\\.(' + ['js'].join('|') + ')$'
|
|
|
// ),
|
|
|
// minRatio: 0.8, // 只有压缩率小于这个值的资源才会被处理
|
|
|
// deleteOriginalAssets: false // 删除原文件
|
|
|
// }
|
|
|
// )
|
|
|
// )
|
|
|
|
|
|
// // 初始化页面的title为配置文件设置的值,public/index.html中的htmlWebpackPlugin.options.title
|
|
|
// config.plugin('html').tap((args) => {
|
|
|
// if (needCdn) {
|
|
|
// args[0].cdn = assetsCDN
|
|
|
// }
|
|
|
// return args
|
|
|
// })
|
|
|
// 视为一个外部库,而不将它打包进来
|
|
|
// config.externals(externals)
|
|
|
|
|
|
|
|
|
// 配置 webpack 识别 markdown 为普通的文件
|
|
|
config.module
|
|
|
.rule('markdown')
|
|
|
.test(/\.md$/)
|
|
|
.use()
|
|
|
.loader('file-loader')
|
|
|
.end()
|
|
|
|
|
|
// 编译vxe-table包里的es6代码,解决IE11兼容问题
|
|
|
config.module
|
|
|
.rule('vxe')
|
|
|
.test(/\.js$/)
|
|
|
.include
|
|
|
.add(resolve('node_modules/vxe-table'))
|
|
|
.add(resolve('node_modules/vxe-table-plugin-antd'))
|
|
|
.end()
|
|
|
.use()
|
|
|
.loader('babel-loader')
|
|
|
.end()
|
|
|
|
|
|
},
|
|
|
|
|
|
css: {
|
|
|
loaderOptions: {
|
|
|
less: {
|
|
|
modifyVars: {
|
|
|
/* less 变量覆盖,用于自定义 ant design 主题 */
|
|
|
'primary-color': '#1890FF',
|
|
|
'link-color': '#1890FF',
|
|
|
'border-radius-base': '4px',
|
|
|
},
|
|
|
javascriptEnabled: true,
|
|
|
}
|
|
|
}
|
|
|
},
|
|
|
|
|
|
devServer: {
|
|
|
port: 3000,
|
|
|
proxy: {
|
|
|
/* '/api': {
|
|
|
target: 'https://mock.ihx.me/mock/5baf3052f7da7e07e04a5116/antd-pro', //mock API接口系统
|
|
|
ws: false,
|
|
|
changeOrigin: true,
|
|
|
pathRewrite: {
|
|
|
'/jeecg-boot': '' //默认所有请求都加了jeecg-boot前缀,需要去掉
|
|
|
}
|
|
|
},*/
|
|
|
'/jeecg-boot': {
|
|
|
target: 'http://172.16.2.47:8080', //请求本地 需要jeecg-boot后台项目
|
|
|
ws: false,
|
|
|
changeOrigin: true
|
|
|
},
|
|
|
}
|
|
|
},
|
|
|
|
|
|
lintOnSave: undefined
|
|
|
} |