forked from wangdabaoqq/vue-drag-tree
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathvue.config.js
83 lines (82 loc) · 1.86 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
const utils = require('./build/utils.js')
const { join } = require('path')
const aliasConfig = require('./config/alias')
const { externalMap } = require('./config/index')
const setAlias = (config) => {
const { alias } = aliasConfig
Object.keys(alias).forEach((key) => {
config.resolve.alias.set(key, alias[key])
})
}
module.exports = {
lintOnSave: utils.isProduct,
runtimeCompiler: true,
productionSourceMap: false,
pages: {
index: {
entry: 'examples/main.js',
template: 'public/index.html',
filename: 'index.html'
}
},
css: {
extract: true,
loaderOptions: {
less: {
javascriptEnabled: true
}
}
},
// 扩展 webpack 配置,使 packages 加入编译
chainWebpack: (config) => {
config.module
.rule('js')
.include.add(join(process.cwd(), 'src'))
.end()
// 设置别名
setAlias(config)
// 关闭利用空余带宽加载文件 提升首页速度
config.plugins.delete('preload')
config.plugins.delete('prefetch')
// 配置别名
config.extensions = aliasConfig.resolve
config.module
.rule('js')
.include.add(/packages/)
.end()
.use('babel')
.loader('babel-loader')
.tap((options) => {
return options
})
config.when(utils.isProduct, (config) => {
// 开启图片压缩
config.module
.rule('images')
.use('image-webpack-loader')
.loader('image-webpack-loader')
.options({
bypassOnDebug: true
})
.end()
})
},
configureWebpack: (config) => {
if (utils.isProduct) {
config.externals = externalMap
}
},
devServer: {
// 端口号
port: 8099,
// eslint报错页面会被遮住
overlay: {
warnings: true,
errors: true
}
},
pluginOptions: {
lintStyleOnBuild: true,
stylelint: {}
}
}