You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
112 lines
2.5 KiB
112 lines
2.5 KiB
const path = require('path')
|
|
const webpack = require('webpack')
|
|
|
|
// 定义一个函数,用于拼接路径
|
|
function resolve (dir) {
|
|
return path.join(__dirname, dir)
|
|
}
|
|
|
|
// vue.config.js
|
|
module.exports = {
|
|
/*
|
|
Vue-cli3:
|
|
Crashed when using Webpack `import()` #2463
|
|
https://github.com/vuejs/vue-cli/issues/2463
|
|
|
|
*/
|
|
/*
|
|
pages: {
|
|
index: {
|
|
entry: 'src/main.js',
|
|
chunks: ['chunk-vendors', 'chunk-common', 'index']
|
|
}
|
|
},
|
|
*/
|
|
// 配置webpack
|
|
configureWebpack: {
|
|
plugins: [
|
|
// 忽略moment.js的所有locale文件
|
|
new webpack.IgnorePlugin(/^\.\/locale$/, /moment$/),
|
|
// 提供全局变量
|
|
new webpack.ProvidePlugin({
|
|
$: 'jquery',
|
|
jQuery: 'jquery'
|
|
})
|
|
]
|
|
},
|
|
|
|
// 链式调用webpack配置
|
|
chainWebpack: (config) => {
|
|
// 设置路径别名
|
|
config.resolve.alias
|
|
.set('@$', resolve('src'))
|
|
.set('@api', resolve('src/api'))
|
|
.set('@assets', resolve('src/assets'))
|
|
.set('@comp', resolve('src/components'))
|
|
.set('@views', resolve('src/views'))
|
|
.set('@layout', resolve('src/layout'))
|
|
.set('@static', resolve('src/static'))
|
|
.set('jquery', resolve('node_modules/jquery/src/jquery'))
|
|
|
|
// 配置svg规则
|
|
const svgRule = config.module.rule('svg')
|
|
svgRule.uses.clear()
|
|
svgRule
|
|
.oneOf('inline')
|
|
.resourceQuery(/inline/)
|
|
.use('vue-svg-icon-loader')
|
|
.loader('vue-svg-icon-loader')
|
|
.end()
|
|
.end()
|
|
.oneOf('external')
|
|
.use('file-loader')
|
|
.loader('file-loader')
|
|
.options({
|
|
name: 'assets/[name].[hash:8].[ext]'
|
|
})
|
|
/* svgRule.oneOf('inline')
|
|
.resourceQuery(/inline/)
|
|
.use('vue-svg-loader')
|
|
.loader('vue-svg-loader')
|
|
.end()
|
|
.end()
|
|
.oneOf('external')
|
|
.use('file-loader')
|
|
.loader('file-loader')
|
|
.options({
|
|
name: 'assets/[name].[hash:8].[ext]'
|
|
})
|
|
*/
|
|
},
|
|
|
|
// 配置css
|
|
css: {
|
|
loaderOptions: {
|
|
less: {
|
|
modifyVars: {
|
|
/* less 变量覆盖,用于自定义 ant design 主题 */
|
|
|
|
/*
|
|
'primary-color': '#F5222D',
|
|
'link-color': '#F5222D',
|
|
'border-radius-base': '4px',
|
|
*/
|
|
},
|
|
javascriptEnabled: true
|
|
}
|
|
}
|
|
},
|
|
|
|
// 配置开发服务器
|
|
devServer: {
|
|
// 开发服务器端口
|
|
port: 8000,
|
|
proxy: 'http://localhost:9527'
|
|
},
|
|
|
|
// 生产环境下禁用source map
|
|
productionSourceMap: false,
|
|
lintOnSave: undefined,
|
|
// babel-loader不忽略node_modules/*
|
|
transpileDependencies: []
|
|
} |