2023-11-02 12:12:37 +00:00
|
|
|
const { defineConfig } = require('@vue/cli-service');
|
|
|
|
|
|
|
|
module.exports = defineConfig({
|
|
|
|
transpileDependencies: true,
|
|
|
|
lintOnSave: false,
|
|
|
|
pages: {
|
|
|
|
management: {
|
|
|
|
entry: `src/management/main.js`,
|
|
|
|
template: 'public/management.html',
|
|
|
|
filename: `management.html`,
|
|
|
|
title: '问卷调研',
|
|
|
|
},
|
|
|
|
render: {
|
|
|
|
entry: `src/render/main.js`,
|
|
|
|
template: 'public/render.html',
|
|
|
|
filename: `render.html`,
|
|
|
|
title: '问卷调研',
|
|
|
|
},
|
|
|
|
},
|
|
|
|
css: {
|
|
|
|
loaderOptions: {
|
|
|
|
sass: {
|
|
|
|
additionalData: `@import "./src/management/styles/variable.scss";`,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
devServer: {
|
|
|
|
proxy: {
|
|
|
|
'/api': {
|
2023-11-13 20:21:18 +00:00
|
|
|
target: 'http://localhost:3000',
|
2023-11-02 12:12:37 +00:00
|
|
|
changeOrigin: true,
|
2023-11-13 20:21:18 +00:00
|
|
|
pathRewrite: false,
|
2023-11-02 12:12:37 +00:00
|
|
|
},
|
|
|
|
},
|
2023-11-13 20:21:18 +00:00
|
|
|
setupMiddlewares(middlewares, devServer) {
|
|
|
|
if (!devServer) {
|
|
|
|
throw new Error('webpack-dev-server is not defined');
|
|
|
|
}
|
|
|
|
devServer.app.get('/', function (req, res) {
|
|
|
|
res.redirect('/management');
|
|
|
|
});
|
|
|
|
return middlewares;
|
|
|
|
},
|
|
|
|
open: true,
|
2023-11-02 12:12:37 +00:00
|
|
|
},
|
|
|
|
chainWebpack: (config) => {
|
|
|
|
config.module
|
|
|
|
.rule('js')
|
|
|
|
.test(/\.jsx?$/)
|
|
|
|
.use('babel-loader')
|
|
|
|
.loader('babel-loader')
|
|
|
|
.end();
|
|
|
|
|
|
|
|
config.optimization.splitChunks({
|
|
|
|
cacheGroups: {
|
|
|
|
setterWidgets: {
|
|
|
|
name: 'setterWidgets',
|
|
|
|
test: /\/setters\/src\/widgets[\\/]/,
|
|
|
|
chunks: 'async',
|
|
|
|
enforce: true,
|
|
|
|
},
|
|
|
|
materialWidgets: {
|
|
|
|
name: 'materialWidgets',
|
|
|
|
test: /\/materials\/questions\/widgets[\\/]/,
|
|
|
|
chunks: 'async',
|
|
|
|
enforce: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
});
|
|
|
|
},
|
|
|
|
});
|