-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathvue.config.js
134 lines (127 loc) · 3.85 KB
/
vue.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
const path = require("path");
function resolve(dir) {
return path.join(__dirname, dir);
}
const CompressionWebpackPlugin = require("compression-webpack-plugin");
const productionGzipExtensions = ["js", "css"];
module.exports = {
outputDir: "web", // 当运行 vue-cli-service build 时生成的生产环境构建文件的目录。注意目标目录在构建之前会被清除 (构建时传入 --no-clean 可关闭该行为)
publicPath: "/",
// productionSourceMap: false,
chainWebpack: config => {
// 添加别名
config.resolve.alias
.set("@", resolve("src"))
.set("~", resolve("node_modules"))
.set("Assets", resolve("src/assets"))
.set("Components", resolve("src/components"))
.set("Config", resolve("src/config"))
.set("Directives", resolve("src/directives"))
.set("Libs", resolve("src/libs"))
.set("Plugins", resolve("src/plugins"))
.set("Routes", resolve("src/routes"))
.set("Service", resolve("src/service"))
.set("Utils", resolve("src/utils"))
.set("Views", resolve("src/views"))
.set("Locale", resolve("src/locale"));
// 修改svg loader
config.module
.rule("svg")
.exclude.add(resolve("src/assets/icons"))
.end();
// 添加svg-sprite-loader
config.module
.rule("svgSpriteLoader")
.test(/\.svg$/)
.include.add(resolve("src/assets/icons"))
.end()
.use("svg-sprite-loader")
.loader("svg-sprite-loader")
.options({
symbolId: "icon-[name]"
})
.end();
// 添加打包分析模式
if (process.env.npm_config_report) {
config
.plugin("webpack-bundle-analyzer")
.use(require("webpack-bundle-analyzer").BundleAnalyzerPlugin);
}
},
configureWebpack: config => {
if (process.env.NODE_ENV === "production") {
// 生产环境 开启gzip
config.plugins.push(
new CompressionWebpackPlugin({
filename: "[path].gz[query]",
algorithm: "gzip",
test: new RegExp("\\.(" + productionGzipExtensions.join("|") + ")$"),
threshold: 10240,
minRatio: 0.8
})
);
// 添加source map
config.devtool = "cheap-module-source-map";
config.optimization = {
splitChunks: {
chunks: "async",
minSize: 200000,
maxSize: 400000,
minChunks: 1,
maxAsyncRequests: 5,
maxInitialRequests: 3,
automaticNameDelimiter: "~",
automaticNameMaxLength: 30,
name: true,
cacheGroups: {
vendors: {
test: /[\\/]node_modules[\\/]/,
priority: -10
},
default: {
minChunks: 2,
priority: -20,
reuseExistingChunk: true
}
}
}
};
}
},
css: {
loaderOptions: {
// 给 sass-loader 传递选项
sass: {
data: `@import "@/assets/style/global.scss";`
}
}
},
devServer: {
port: 3000,
overlay: {
warnings: true,
errors: true
},
proxy: {
"^/api": {
//target: "https://192.168.1.17:9527",
//target: "https://kusama.subscan.io", // 接口的域名
// target: "https://icefrog.subscan.io", // 接口的域名
target: "https://edgeware.subscan.io/", // 接口的域名
secure: true, // 如果是https接口,需要配置这个参数
changeOrigin: true, // 如果接口跨域,需要进行这个参数配置
pathRewrite: {
"^/api": "/api"
}
},
"^/test": {
target: "https://kusama.subscan.io", // 接口的域名
secure: true, // 如果是https接口,需要配置这个参数
changeOrigin: true, // 如果接口跨域,需要进行这个参数配置
pathRewrite: {
"/test": ""
}
}
}
}
};