123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215 |
- 'use strict'
- const path = require('path')
- const FileManagerPlugin = require("filemanager-webpack-plugin");
- function resolve(dir) {
- return path.join(__dirname, dir)
- }
- // If your port is set to 80,
- // use administrator privileges to execute the command line.
- // For example, Mac: sudo npm run
- // You can change the port by the following methods:
- // port = 9528 npm run dev OR npm run dev --port = 9528
- const port = process.env.port || process.env.npm_config_port || 9528 // dev port
- // All configuration item explanations can be find in https://cli.vuejs.org/config/
- module.exports = {
- /**
- * You will need to set publicPath if you plan to deploy your site under a sub path,
- * for example GitHub Pages. If you plan to deploy your site to https://foo.github.io/bar/,
- * then publicPath should be set to "/bar/".
- * In most cases please use '/' !!!
- * Detail: https://cli.vuejs.org/config/#publicpath
- */
- publicPath: './',
- outputDir: 'dist/SzLivePlatformManageFront',
- assetsDir: 'static',
- lintOnSave: process.env.NODE_ENV === 'development',
- productionSourceMap: false,
- devServer: {
- port: port,
- open: true,
- overlay: {
- warnings: false,
- errors: true
- }
- },
- configureWebpack: config => {
- config.devServer = {
- proxy: {
- // "^/user": {target: "http://192.168.58.137:10086"},
- // "^/(user|goods|goodsTypes|order|orderItem|rooms|room)/": { target: "http://127.0.0.1:10086" },
- // "^/.*": { target: "http://116.63.32.160:8085" },
- "^/.*": { target: "http://127.0.0.1:10086" },
- },
- }
- if (process.env.NODE_ENV != 'development') {
- config.plugins.push(new FileManagerPlugin({
- events: {
- onStart: {
- delete: [`dist/SzLivePlatformManageFront`]
- },
- onEnd: {
- archive: [
- {
- source: `dist/SzLivePlatformManageFront`,
- destination: `dist/SzLivePlatformManageFront.zip`,
- format: 'zip',
- options: {
- gzip: true,
- gzipOptions: {
- level: 1
- },
- globOptions: {
- nomount: true
- }
- }
- }
- ]
- }
- }
- }))
- }
- },
- // configureWebpack: {
- // // provide the app's title in webpack's name field, so that
- // // it can be accessed in index.html to inject the correct title.
- // resolve: {
- // alias: {
- // '@': resolve('src')
- // }
- // },
- // devServer: {
- // proxy: {
- // // "^/user": {target: "http://192.168.58.137:10086"},
- // // "^/(user|goods|goodsTypes|order|orderItem|rooms|room)/": { target: "http://127.0.0.1:10086" },
- // // "^/.*": { target: "http://116.63.32.160:8085" },
- // "^/.*": { target: "http://127.0.0.1:10086" },
- // },
- // // plugins: process.env.NODE_ENV == 'production'? [
- // // new FileManagerPlugin({
- // // events: {
- // // onStart: {
- // // delete: [`dist/${page}`]
- // // },
- // // onEnd: {
- // // archive: [
- // // {
- // // source: `dist/SzLivePlatformManageFront`,
- // // destination: `dist/SzLivePlatformManageFront.zip`,
- // // format: 'zip',
- // // options: {
- // // gzip: true,
- // // gzipOptions: {
- // // level: 1
- // // },
- // // globOptions: {
- // // nomount: true
- // // }
- // // }
- // // }
- // // ]
- // // }
- // // }
- // // })
- // // ]: []
- // }
- // },
- chainWebpack(config) {
- // it can improve the speed of the first screen, it is recommended to turn on preload
- config.plugin('preload').tap(() => [
- {
- rel: 'preload',
- // to ignore runtime.js
- // https://github.com/vuejs/vue-cli/blob/dev/packages/@vue/cli-service/lib/config/app.js#L171
- fileBlacklist: [/\.map$/, /hot-update\.js$/, /runtime\..*\.js$/],
- include: 'initial'
- }
- ])
- config.optimization.minimizer('terser').tap((args) => {
- args[0].terserOptions.compress.drop_console = true;
- return args;
- })
- // when there are many pages, it will cause too many meaningless requests
- config.plugins.delete('prefetch')
- // set svg-sprite-loader
- 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', [{
- // `runtime` must same as runtimeChunk name. default is `runtime`
- inline: /runtime\..*\.js$/
- }])
- .end()
- config
- .optimization.splitChunks({
- chunks: 'all',
- cacheGroups: {
- libs: {
- name: 'libs',
- priority: 50,
- chunks: 'initial',
- },
- elementUI: {
- name: 'elementUI', // split elementUI into a single package
- priority: 40,
- test: /[\\/]node_modules[\\/]_?element-ui(.*)/,
- },
- avue: {
- name: 'avue', // split avue into a single package
- priority: 40,
- test: /[\\/]node_modules[\\/]@smallwei(.*)/,
- reuseExistingChunk: true
- },
- echarts: {
- name: 'echarts',
- test: /[\\/]node_modules[\\/](?:vue-)?echarts/,
- priority: 40,
- },
- utils: {
- name: 'utils',
- test: /[\\/]src[\\/]utils|[\\/]node_modules[\\/](lodash|axios|crypto-js)/,
- priority: 30,
- },
- styles: {
- name: 'styles', // pack all remaining style files
- test: /\.(css|scss)$/,
- priority: 45,
- reuseExistingChunk: true
- },
- }
- })
- }
- )
- }
- }
|