const path = require('path') const CompressionPlugin = require('compression-webpack-plugin') function resolve(dir) { return path.join(__dirname, dir) } // vue.config.js module.exports = { runtimeCompiler: true, /* Vue-cli3: Crashed when using Webpack `import()` #2463 https://github.com/vuejs/vue-cli/issues/2463 */ // 如果你不需要生产环境的 source map,可以将其设置为 false 以加速生产环境构建。 productionSourceMap: false, // qiankuan打包时放开 // outputDir: "../dist/main", // 多入口配置 // pages: { // index: { // entry: 'src/main.js', // template: 'public/index.html', // filename: 'index.html', // } // }, // 打包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')) // 生产环境,开启js\css压缩 if (process.env.NODE_ENV === 'production') { config.plugin('compressionPlugin').use(new CompressionPlugin({ test: /\.(js|css|less)$/, // 匹配文件名 threshold: 10240, // 对超过10k的数据压缩 deleteOriginalAssets: false // 不删除源文件 })) } // 配置 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() config.module .rule('ol') .test(/\.js$/) .include .add(resolve('node_modules/ol')) .end() .use() .loader('babel-loader') .options({ presets: ['@babel/preset-env'], plugins: ['@babel/plugin-proposal-nullish-coalescing-operator'] }) .end() }, css: { loaderOptions: { less: { modifyVars: { /* less 变量覆盖,用于自定义 ant design 主题 */ 'primary-color': '#1397a3', 'link-color': '#1397a3', 'border-radius-base': '4px', 'text-color': '#fff' }, javascriptEnabled: true } } }, devServer: { port: 3000, // hot: true, // disableHostCheck: true, // overlay: { // warnings: false, // errors: true, // }, // headers: { // 'Access-Control-Allow-Origin': '*', // }, proxy: { /* '/api': { target: 'https://mock.ihx.me/mock/5baf3052f7da7e07e04a5116/antd-pro', //mock API接口系统 ws: false, changeOrigin: true, pathRewrite: { '/jeecg-boot': '' //默认所有请求都加了jeecg-boot前缀,需要去掉 } }, */ /* 注意:jeecgboot前端做了改造,此处不需要配置跨域和后台接口(只需要改.env相关配置文件即可) issues/3462 很多人此处做了配置,导致刷新前端404问题,请一定注意 */ '/jeecg-boot': { target: 'http://localhost:8080', ws: false, changeOrigin: true } } }, lintOnSave: undefined }