-
Notifications
You must be signed in to change notification settings - Fork 0
/
vite.config.js
140 lines (133 loc) · 3.96 KB
/
vite.config.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
import path from 'path';
import vue from '@vitejs/plugin-vue';
import vueJsx from '@vitejs/plugin-vue-jsx';
const PORT = process.env.PORT || 10001;
import { myDomain } from './src/config/index';
const cookies = {
current: null
};
const config = {
plugins: [
vueJsx({
// options are passed on to @vue/babel-plugin-jsx
}),
vue(),
],
/**
* 在生产中服务时的基本公共路径。
* @default '/'
*/
base: '/',
/**
* 与“根”相关的目录,构建输出将放在其中。如果目录存在,它将在构建之前被删除。
* @default 'dist'
*/
outDir: 'dist',
port: PORT,
cors: true,
emitManifest: true,
// 是否自动在浏览器打开
open: false,
// 是否开启 https
https: false,
// 服务端渲染
ssr: false,
// 引入第三方的配置
optimizeDeps: {
include: ['axios'],
exclude: [
'qiankun',
'json-server',
'koa2',
'koa-body',
'swiper',
'autoprefixer',
'koa-static-cache',
'@vue/server-renderer',
'vue-style-loader'
]
},
resolve: {
alias: {
// vite中alias必须以斜线开头和结尾,暂时未知原因,这样其实挺不方便的
// 所以在eslint配置alias和文件中导入路径也要相应的修改
'/@': path.resolve(__dirname, './src')
// 'vue': path.resolve(__dirname, './node_modules/vue/dist/vue.runtime.esm-browser.js'),
}
},
//这里注意,键名是scss不是sass!一字之差能让你折腾好久
scss: {
//这里写你想导入全局scss变量的路径
//这里注意只能写相对路径,alias貌似在css中不会生效
additionalData: "@import './src/style/a.scss';"
},
define: {
'process.env': JSON.stringify({
NODE_ENV: '"development"',
VUE_ENV: '"client"'
}),
'process.server': false,
__IS_PROD__: false,
__SERVER__: false
},
proxy: {
// '/api': 'http://127.0.0.1:10002',
// 如果是 /api 打头,则访问地址如下
'/api': {
target: `https://t-api.${myDomain}`,
// target: 'http://127.0.0.1:10002',
headers: {
origin: `https://t-h5.${myDomain}`,
referer: `https://t-h5.${myDomain}/`,
'sec-fetch-site': 'same-site',
'sec-fetch-mode': 'cors',
'sec-fetch-dest': 'empty'
},
changeOrigin: true, // 是否跨域
secure: true, // 是否https接口
logs(ctx, target) {
console.log(
'%s - %s %s proxy to -> %s',
new Date().toISOString(),
ctx.req.method,
ctx.req.oldPath,
new URL(ctx.req.url, target)
);
},
// rewrite: (e, a) => {
// console.log('rewrite e', e);
// console.log('rewrite a', a);
// console.log('new Date', new Date().toLocaleTimeString());
// return e;
// }
events: {
error(err, req, res) {
console.log('err', err);
},
proxyReq(proxyReq, req, res) {
proxyReq._headers.cookie =
proxyReq._headers.cookie || cookies.current;
console.log('\nproxyReq headers', proxyReq._headers.cookie);
},
proxyRes(proxyRes, req, res) {
console.log('\nstatusCode', proxyRes.statusCode);
console.log('\nstatusMessage', proxyRes.statusMessage);
console.log('\nheaders', proxyRes.headers);
proxyRes.headers['access-control-allow-origin'] =
req.headers['origin'];
if (proxyRes.headers['set-cookie'] !== undefined) {
console.log('** SET-COOKIE: ', proxyRes.headers['set-cookie']);
cookies.current = proxyRes.headers['set-cookie']
.map(d => d.replace(/Path=.+$/, ''))
.join(';');
console.log('cookies.current', cookies.current);
proxyRes.headers['set-cookie'] = proxyRes.headers[
'set-cookie'
].map(d => d.replace(/Domain=\w+\.\w+;/, ``));
}
}
}
}
}
};
export default config;