2018-07-16 22:22:55 +08:00
|
|
|
// 拼接路径
|
2018-10-27 18:48:22 +08:00
|
|
|
const resolve = dir => require('path').join(__dirname, dir)
|
2018-07-16 22:22:55 +08:00
|
|
|
|
2018-07-20 18:24:47 +08:00
|
|
|
// 基础路径 注意发布之前要先修改这里
|
2018-09-13 18:01:39 +08:00
|
|
|
let baseUrl = '/'
|
2018-07-20 18:24:47 +08:00
|
|
|
|
2018-07-16 22:22:55 +08:00
|
|
|
module.exports = {
|
2018-07-20 18:24:47 +08:00
|
|
|
baseUrl: baseUrl, // 根据你的实际情况更改这里
|
2018-07-16 22:22:55 +08:00
|
|
|
lintOnSave: true,
|
|
|
|
|
devServer: {
|
2018-07-20 18:24:47 +08:00
|
|
|
publicPath: baseUrl // 和 baseUrl 保持一致
|
2018-07-16 22:22:55 +08:00
|
|
|
},
|
2018-11-16 22:49:27 +08:00
|
|
|
css: {
|
|
|
|
|
loaderOptions: {
|
|
|
|
|
// 设置 scss 公用变量文件
|
|
|
|
|
sass: {
|
|
|
|
|
data: `@import '~@/assets/style/public.scss';`
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
},
|
2018-07-19 17:00:45 +08:00
|
|
|
// 默认设置: https://github.com/vuejs/vue-cli/tree/dev/packages/%40vue/cli-service/lib/config/base.js
|
2018-07-16 22:22:55 +08:00
|
|
|
chainWebpack: config => {
|
2018-09-12 08:10:16 +08:00
|
|
|
// 解决 cli3 热更新失效 https://github.com/vuejs/vue-cli/issues/1559
|
|
|
|
|
config.resolve
|
|
|
|
|
.symlinks(true)
|
2018-07-16 22:22:55 +08:00
|
|
|
// markdown
|
|
|
|
|
config.module
|
|
|
|
|
.rule('md')
|
|
|
|
|
.test(/\.md$/)
|
|
|
|
|
.use('text-loader')
|
|
|
|
|
.loader('text-loader')
|
|
|
|
|
.end()
|
|
|
|
|
// i18n
|
|
|
|
|
config.module
|
|
|
|
|
.rule('i18n')
|
|
|
|
|
.resourceQuery(/blockType=i18n/)
|
|
|
|
|
.use('i18n')
|
|
|
|
|
.loader('@kazupon/vue-i18n-loader')
|
|
|
|
|
.end()
|
|
|
|
|
// svg
|
|
|
|
|
const svgRule = config.module.rule('svg')
|
|
|
|
|
svgRule.uses.clear()
|
|
|
|
|
svgRule
|
|
|
|
|
.include
|
2018-07-17 16:14:19 +08:00
|
|
|
.add(resolve('src/assets/svg-icons/icons'))
|
2018-07-16 22:22:55 +08:00
|
|
|
.end()
|
|
|
|
|
.use('svg-sprite-loader')
|
|
|
|
|
.loader('svg-sprite-loader')
|
|
|
|
|
.options({
|
|
|
|
|
symbolId: 'd2-[name]'
|
|
|
|
|
})
|
|
|
|
|
.end()
|
2018-07-25 09:47:43 +08:00
|
|
|
// image exclude
|
2018-07-16 22:22:55 +08:00
|
|
|
const imagesRule = config.module.rule('images')
|
|
|
|
|
imagesRule
|
|
|
|
|
.test(/\.(png|jpe?g|gif|webp|svg)(\?.*)?$/)
|
|
|
|
|
.exclude
|
2018-07-17 16:14:19 +08:00
|
|
|
.add(resolve('src/assets/svg-icons/icons'))
|
2018-07-16 22:22:55 +08:00
|
|
|
.end()
|
2018-07-17 21:54:38 +08:00
|
|
|
// 重新设置 alias
|
2018-07-19 17:00:45 +08:00
|
|
|
config.resolve.alias
|
2018-07-17 21:54:38 +08:00
|
|
|
.set('@', resolve('src'))
|
2018-11-15 06:43:27 +08:00
|
|
|
// node
|
|
|
|
|
config.node
|
|
|
|
|
.set('__dirname', true)
|
|
|
|
|
.set('__filename', true)
|
2018-07-19 17:00:45 +08:00
|
|
|
// babel-polyfill 加入 entry
|
|
|
|
|
const entry = config.entry('app')
|
|
|
|
|
entry
|
|
|
|
|
.add('babel-polyfill')
|
|
|
|
|
.end()
|
2018-11-14 19:48:44 +08:00
|
|
|
// 判断环境加入模拟数据
|
2018-11-14 16:24:56 +08:00
|
|
|
if (process.env.VUE_APP_BUILD_MODE !== 'nomock') {
|
|
|
|
|
entry
|
|
|
|
|
.add('@/mock')
|
|
|
|
|
.end()
|
|
|
|
|
}
|
2018-07-16 22:22:55 +08:00
|
|
|
}
|
|
|
|
|
}
|