goindex-theme-r/vue.config.js

110 lines
2.8 KiB
JavaScript
Raw Normal View History

2020-04-28 02:16:41 +08:00
const path = require("path");
2020-05-03 15:10:01 +08:00
const cdnDependencies = require("./dependencies-cdn");
2020-05-06 20:45:18 +08:00
const BuildAppJSPlugin = require("./buildAppJSPlugin");
const CompressionWebpackPlugin = require('compression-webpack-plugin')
2020-04-24 19:43:00 +08:00
2020-04-28 02:16:41 +08:00
function resolve(dir) {
return path.join(__dirname, dir);
2020-04-24 19:43:00 +08:00
}
2020-04-28 19:02:48 +08:00
// 增加环境变量
2020-05-17 01:57:33 +08:00
process.env.VUE_APP_VERSION = require('./package.json').version
process.env.VUE_APP_G2INDEX_VERSION = require('./package.json').g2index
2020-04-28 19:02:48 +08:00
// 基础路径 注意发布之前要先修改这里
2020-05-03 15:10:01 +08:00
let publicPath = process.env.VUE_APP_PUBLIC_PATH || "/";
2020-04-28 19:02:48 +08:00
// 设置不参与构建的库
2020-05-03 15:10:01 +08:00
let externals = {};
cdnDependencies.forEach((item) => {
externals[item.name] = item.library;
});
2020-04-28 19:02:48 +08:00
// 引入文件的 cdn 链接
const cdn = {
2020-05-03 15:10:01 +08:00
css: cdnDependencies.map((e) => e.css).filter((e) => e),
js: cdnDependencies.map((e) => e.js).filter((e) => e),
};
2020-04-24 19:43:00 +08:00
module.exports = {
2020-04-28 19:02:48 +08:00
publicPath,
2020-04-28 02:16:41 +08:00
lintOnSave: true,
2020-05-02 20:54:21 +08:00
2020-05-03 15:10:01 +08:00
configureWebpack: (config) => {
const configNew = {}
if (process.env.NODE_ENV === 'production') {
configNew.externals = externals
configNew.plugins = [
// gzip
new CompressionWebpackPlugin({
filename: '[path].gz[query]',
test: new RegExp('\\.(' + ['js', 'css'].join('|') + ')$'),
threshold: 10240,
minRatio: 0.8,
deleteOriginalAssets: false
})
]
2020-04-28 19:02:48 +08:00
}
return configNew
2020-04-28 19:02:48 +08:00
},
2020-05-02 20:54:21 +08:00
2020-04-28 02:16:41 +08:00
chainWebpack: (config) => {
2020-05-06 20:45:18 +08:00
config.plugin("BuildAppJSPlugin").use(BuildAppJSPlugin);
2020-04-28 19:02:48 +08:00
/**
* 添加 CDN 参数到 htmlWebpackPlugin 配置中
*/
2020-05-03 15:10:01 +08:00
config.plugin("html").tap((args) => {
if (process.env.NODE_ENV === "production") {
args[0].cdn = cdn;
2020-04-28 19:02:48 +08:00
} else {
2020-05-03 15:10:01 +08:00
args[0].cdn = {
js: cdnDependencies.filter((e) => e.name === "").map((e) => e.js),
2020-05-06 20:45:18 +08:00
css: cdnDependencies.filter((e) => e.name === "").map((e) => e.css),
2020-05-03 15:10:01 +08:00
};
2020-04-28 19:02:48 +08:00
}
2020-05-06 20:45:18 +08:00
args[0].inject = false
2020-05-03 15:10:01 +08:00
return args;
});
// 解决 cli3 热更新失效 https://github.com/vuejs/vue-cli/issues/1559
config.resolve
.symlinks(true)
2020-04-28 02:16:41 +08:00
config.resolve.alias
.set("@", resolve("src"))
.set("@assets", resolve("src/assets"))
.set("@utils", resolve("src/utils"))
.set("@node_modules", resolve("node_modules"));
2020-04-28 19:02:48 +08:00
// 分析工具
if (process.env.npm_config_report) {
config
2020-05-03 15:10:01 +08:00
.plugin("webpack-bundle-analyzer")
.use(require("webpack-bundle-analyzer").BundleAnalyzerPlugin);
2020-04-28 19:02:48 +08:00
}
2020-04-28 02:16:41 +08:00
},
2020-05-02 20:54:21 +08:00
2020-04-28 19:02:48 +08:00
// 不输出 map 文件
productionSourceMap: false,
2020-05-02 20:54:21 +08:00
2020-04-28 02:16:41 +08:00
devServer: {
2020-04-28 19:02:48 +08:00
publicPath,
2020-04-28 02:16:41 +08:00
proxy: {
"/api": {
target: "https://ossdev.achirou.workers.dev/",
ws: true,
changeOrigin: true,
pathRewrite: {
"^/api": "",
},
},
2020-04-24 19:43:00 +08:00
},
2020-04-28 02:16:41 +08:00
},
2020-05-02 20:54:21 +08:00
pluginOptions: {
i18n: {
2020-05-03 15:10:01 +08:00
locale: "zh-chs",
fallbackLocale: "en",
localeDir: "locales",
enableInSFC: true,
},
},
2020-05-02 20:54:21 +08:00
};