-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathvue.config.js
201 lines (169 loc) · 6.99 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
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
/**
*
* @authors YafullyZhao ([email protected])
* @date 2019-02-12 11:25:04
* @version $Id$
*/
//const needBabelPolyFill = true
const glob = require('glob')
let path = require('path')
function resolve (dir) {
return path.join(__dirname, dir)
}
/** 获取多页的入口脚本和模板 */
const getPages = (() => {
const [globPathHtml, globPathJs, pages, tempSet] = [
['./src/views/**/*.html', 'template'], // 入口模板正则
['./src/views/**/app.js', 'entry'], // 入口脚本正则
Object.create(null),
new Set()
]
const getMultiPageConf = (globPath, keyName) => {
let [fileList, tempArr, modName] = [glob.sync(globPath), [], null]
if (fileList.length !== 0) {
for (let entry of fileList) {
tempArr = path.dirname(entry, path.extname(entry)).split('/')
modName = tempArr[tempArr.length - 1]
//let jsPath = needBabelPolyFill ? {'app': ['babel-polyfill', entry]} : entry
if (tempSet.has(modName)) {
Object.assign(pages[modName], { [keyName]: entry, 'filename': `${modName}.html` })
} else {
Reflect.set(pages, modName, { [keyName]: entry }) && tempSet.add(modName)
}
}
return true
} else {
if (keyName === 'template') {
throw new Error('无法获取多页入口模板')
} else if (keyName === 'entry') {
throw new Error('无法获取多页入口脚本')
} else {
throw new Error('无法获取多页信息')
}
}
}
try {
while (getMultiPageConf(...globPathHtml) && getMultiPageConf(...globPathJs)) return pages
} catch (err) {
console.log('获取多页数据错误:', err)
}
})()
console.log('pages: ', getPages)
module.exports = {
/** 区分打包环境与开发环境
* process.env.NODE_ENV==='production' (打包环境)
* process.env.NODE_ENV==='development' (开发环境)
* baseUrl: process.env.NODE_ENV==='production'?"https://cdn.didabisai.com/front/":'front/',
*/
// 项目部署的基础路径
// 我们默认假设你的应用将会部署在域名的根部,
// 例如 https://www.my-app.com/
// 如果你的应用部署在一个子路径下,那么你需要在这里
// 指定子路径。比如将你的应用部署在
// https://www.foobar.com/my-app/
// 那么将这个值改为 '/my-app/'
publicPath: "/project", // 构建好的文件输出到哪里
outputDir: "dist", // where to put static assets (js/css/img/font/...) // 是否在保存时使用‘eslint-loader’进行检查 // 有效值: true | false | 'error' // 当设置为‘error’时,检查出的错误会触发编译失败
lintOnSave: true,//process.env.NODE_ENV !== 'production', // 使用带有浏览器内编译器的完整构建版本 // https://vuejs.org/v2/guide/installation.html#Runtime-Compiler-vs-Runtime-only
runtimeCompiler: false, // babel-loader默认会跳过`node_modules`依赖. // 通过这个选项可以显示转译一个依赖
transpileDependencies: [
/* string or regex */
], // 是否为生产环境构建生成sourceMap?
productionSourceMap: false, // 调整内部的webpack配置. // see https://github.com/vuejs/vue-cli/blob/dev/docs/webpack.md
// 构建多页面应用,页面的配置
pages: getPages,
// pages: {
// index: {
// // page 的入口
// entry: 'src/index/main.js',
// // 模板来源
// template: 'public/index.html',
// // 在 dist/index.html 的输出
// filename: 'index.html',
// // 当使用 title 选项时,
// // template 中的 title 标签需要是 <title><%= htmlWebpackPlugin.options.title %></title>
// title: 'Index Page',
// // 在这个页面中包含的块,默认情况下会包含
// // 提取出来的通用 chunk 和 vendor chunk。
// chunks: ['chunk-vendors', 'chunk-common', 'index']
// },
// // 当使用只有入口的字符串格式时,
// // 模板会被推导为 `public/subpage.html`
// // 并且如果找不到的话,就回退到 `public/index.html`。
// // 输出文件名会被推导为 `subpage.html`。
// subpage: 'src/subpage/main.js'
// },
//webpack 配置设置自定义路径
chainWebpack: config => {
//路径转义
config.resolve.alias.set('@', resolve('src')) // key,value自行定义,比如.set('@@', resolve('src/components'))
config.resolve.alias.set('@css', resolve('src/assets/css'))
config.resolve.alias.set('@less', resolve('src/assets/less'))
config.resolve.alias.set('@img', resolve('src/assets/images'))
config.resolve.alias.set('@api', resolve('src/api'))
config.resolve.alias.set('@common', resolve('src/common'))
config.resolve.alias.set('@comp', resolve('src/components'))
config.resolve.alias.set('@views', resolve('src/views'))
config.resolve.alias.set('@vendor', resolve('src/vendor'))
//config.entry('app').add('babel-polyfill')
},
configureWebpack: () => {}, // CSS 相关选项
// configureWebpack: config => {
// //配置vux-loader
// require('vux-loader').merge(config, {
// options: {},
// plugins: ['vux-ui']
// })
// },
css: {
// 是否将组件中的 CSS 提取至一个独立的 CSS 文件中,当作为一个库构建时,你也可以将其设置为 false 免得用户自己导入 CSS
// 默认生产环境下是 true,开发环境下是 false
extract: false,
// 是否为 CSS 开启 source map。设置为 true 之后可能会影响构建的性能
sourceMap: false,
//向 CSS 相关的 loader 传递选项(支持 css-loader postcss-loader sass-loader less-loader stylus-loader)
loaderOptions: {
css: {},
less: {}
},
// 当为true时(会引起element-ui因为font无法编译),css文件名可省略 module 默认为 false
modules: false
},
parallel: require("os").cpus().length > 1, // PWA 插件相关配置 // see https://github.com/vuejs/vue-cli/tree/dev/packages/%40vue/cli-plugin-pwa
pwa: {}, // configure webpack-dev-server behavior
devServer: {
disableHostCheck: false,
https: false,
hotOnly: false, // See https://github.com/vuejs/vue-cli/blob/dev/docs/cli-service.md#configuring-proxy
port: 8888, // 本地端口号
host: 'localhost',
https: false, // https:{type:Boolean}
open: true, //配置自动启动浏览器
// proxy: 'http://localhost:4000' // 配置跨域处理,只有一个代理
proxy: {
'/api': {
target: 'http://localhost:8888',
pathRewrite: {
'^/api': '/mock'
},
ws: true,
changeOrigin: true
}
// ,
// '/foo': {
// target: '<other_url>'
// }
}
// before: app => {}
}, // 第三方插件配置
pluginOptions: {
'style-resources-loader': {
preProcessor: 'less',
patterns: [
//这个是加上自己的路径,
//注意:试过不能使用别名路径
//path.resolve(__dirname, './src/common/less/index.less')
]
}
}
};