const path = require('path') // eslint-disable-next-line quotes const CompressionPlugin = require("compression-webpack-plugin") function resolve(dir) { return path.join(__dirname, dir) } // vue.config.js module.exports = { /* Vue-cli3: Crashed when using Webpack `import()` #2463 https://github.com/vuejs/vue-cli/issues/2463 配置文档 https://cli.vuejs.org/zh/config/ */ // 如果你不需要生产环境的 source map,可以将其设置为 false 以加速生产环境构建。 productionSourceMap: false, // 多入口配置 // pages: { // index: { // entry: 'src/main.js', // template: 'public/index.html', // filename: 'index.html', // } // }, pages: { a: { // page 的入口 entry: 'src/main.js', // 模板来源 template: 'public/index.html', // 在 dist/index.html 的输出 filename: 'a/index.html', // 当使用 title 选项时, // template 中的 title 标签需要是 <%= htmlWebpackPlugin.options.title %> title: '后台管理系统' // 在这个页面中包含的块,默认情况下会包含 // 提取出来的通用 chunk 和 vendor chunk。 // chunks: ['chunk-vendors', 'chunk-common', 'index'] }, // 当使用只有入口的字符串格式时, // 模板会被推导为 `public/subpage.html` // 并且如果找不到的话,就回退到 `public/index.html`。 // 输出文件名会被推导为 `subpage.html`。 // phone: 'src/main_app.js' index: { // page 的入口 entry: 'src/main_gateway.js', // 模板来源 template: 'public/gateway/index.html', // 在 dist/index.html 的输出 filename: 'index.html', // 当使用 title 选项时, // template 中的 title 标签需要是 <%= htmlWebpackPlugin.options.title %> title: '农大国际部' // 在这个页面中包含的块,默认情况下会包含 // 提取出来的通用 chunk 和 vendor chunk。 // chunks: ['chunk-vendors', 'chunk-common', 'index'] } }, // 打包app时放开该配置 // publicPath: './', configureWebpack: config => { // 生产环境取消 console.log if (process.env.NODE_ENV === 'production') { config.optimization.minimizer[0].options.terserOptions.compress.drop_console = true } }, chainWebpack: (config) => { 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')) .set('@layout', resolve('src/layout')) .set('@static', resolve('src/static')) .set('@mobile', resolve('src/modules/mobile')) // 生产环境,开启js\css压缩 if (process.env.NODE_ENV === 'production') { config.plugin('compressionPlugin').use(new CompressionPlugin({ test: /\.(js|css|less)$/, // 匹配文件名 threshold: 10240, // 对超过10k的数据压缩 deleteOriginalAssets: false, // 不删除源文件 minRatio: 0.8, // 只有压缩率比这个值小的资源才会被处理 algorithm: 'gzip', filename: '[path].gz[query]' // 目标资源名称 })) } // 配置 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': '#07a54d', 'link-color': '#07a54d', 'border-radius-base': '4px' }, javascriptEnabled: true } } }, devServer: { port: 3001, 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://localhost:8080', // 请求本地 需要jeecg-boot后台项目 ws: false, changeOrigin: true } } }, lintOnSave: undefined }