123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147 |
- 'use strict'
- const path = require('path')
- function resolve(dir) {
- return path.join(__dirname, dir)
- }
- const port = process.env.port || process.env.npm_config_port || 9528
- module.exports = {
-
- publicPath: './',
- outputDir: 'dist',
- assetsDir: 'static',
- lintOnSave: process.env.NODE_ENV === 'development',
- productionSourceMap: false,
- devServer: {
- port: port,
- open: true,
- overlay: {
- warnings: false,
- errors: true
- }
- },
- configureWebpack: {
-
-
- resolve: {
- alias: {
- '@': resolve('src')
- }
- },
- devServer: {
- proxy: {
-
- "^/(user|goods|goodsTypes|order|orderItem|rooms)/": { target: "http://127.0.0.1:10086" },
- "^/.*": { target: "http://116.63.32.160:8085" },
- },
- }
- },
- chainWebpack(config) {
-
- config.plugin('preload').tap(() => [
- {
- rel: 'preload',
-
-
- fileBlacklist: [/\.map$/, /hot-update\.js$/, /runtime\..*\.js$/],
- include: 'initial'
- }
- ])
-
- config.plugins.delete('prefetch')
-
- config.module
- .rule('svg')
- .exclude.add(resolve('src/icons'))
- .end()
- config.module
- .rule('icons')
- .test(/\.svg$/)
- .include.add(resolve('src/icons'))
- .end()
- .use('svg-sprite-loader')
- .loader('svg-sprite-loader')
- .end()
- config
- .when(process.env.ANALYZER == 'true', config => {
- const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin
- config.plugin('webpack-bundle-analyzer').use(BundleAnalyzerPlugin).tap(() => [
- {
- analyzerPort: "auto"
- }
- ])
- })
- config
- .when(process.env.NODE_ENV !== 'development',
- config => {
- config
- .plugin('ScriptExtHtmlWebpackPlugin')
- .after('html')
- .use('script-ext-html-webpack-plugin', [{
-
- inline: /runtime\..*\.js$/
- }])
- .end()
- config
- .optimization.splitChunks({
- chunks: 'all',
- cacheGroups: {
- libs: {
- name: 'libs',
-
- priority: 50,
- chunks: 'initial',
- },
- elementUI: {
- name: 'elementUI',
- priority: 40,
- test: /[\\/]node_modules[\\/]_?element-ui(.*)/,
- chunks: 'async',
- },
- avue: {
- name: 'avue',
- priority: 41,
- test: /[\\/]node_modules[\\/]@smallwei(.*)/,
- chunks: 'async',
- reuseExistingChunk: true
- },
- utils: {
- name: 'utils',
- test: /([\\/]src[\\/]utils)|lodash|axios|crypto-js/,
- priority: 30,
- chunks: 'async',
- },
- styles: {
- name: 'styles',
- test: /\.(css|scss)$/,
- priority: 45,
- chunks: 'all',
- reuseExistingChunk: true
- }
- }
- })
-
- config.optimization.runtimeChunk(false)
- }
- )
- }
- }
|