123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274 |
- const { resolve } = require('path')
- const path = require('path')
- const WebpackBar = require('webpackbar')
- // const dayjs = require('dayjs')
- // const time = dayjs().format('YYYY-M-D HH:mm:ss')
- const merge = require('webpack-merge')
- const tsImportPluginFactory = require('ts-import-plugin')
- const UglifyJsPlugin = require('uglifyjs-webpack-plugin')
- const productionGzipExtensions = ['js', 'css', 'svg']
- // process.env.VUE_APP_UPDATE_TIME = time
- const isProduction = process.env.NODE_ENV === 'production'
- // const cdn = {
- // css: ['https://cdn.jsdelivr.net/npm/vant@3/lib/index.css'],
- // js: ['https://unpkg.com/vue@3.2.31/dist/vue.global.js',
- // 'https://unpkg.com/vue-router@4.0.14/dist/vue-router.global.js',
- // 'https://unpkg.com/vuex@4.0.2/dist/vuex.global.js',
- // 'https://cdn.jsdelivr.net/npm/vant@3/lib/vant.min.js',
- // 'https://cdn.jsdelivr.net/npm/echarts@5.3.2/dist/echarts.min.js'
- // ]
- // }
- const {
- publicPath,
- assetsDir,
- parallel,
- outputDir,
- lintOnSave,
- transpileDependencies,
- title,
- devPort,
- } = require('./src/config/default/vue.custom.config')
- const CompressionPlugin = require('compression-webpack-plugin')
- const webpack = require('webpack')
- module.exports = {
- publicPath,
- assetsDir,
- parallel,
- outputDir,
- lintOnSave,
- transpileDependencies,
- // css: {
- // loaderOptions: {
- // postcss: {
- // plugins: [
- // require('postcss-px2rem-exclude')({
- // 'remUnit':98, //设计稿是750,那么这里的设置就是填750/10=75
- // 'propList': ['*', '!border','!border-left','!border-right'],
- // 'exclude': /node_modules|folder_name/i // 解决UI库px转rem问题 配置忽略node包
- // })
- // ]
- // }
- // },
- // },
- css: {
- loaderOptions: {
- postcss: {
- plugins: [
- require('postcss-pxtorem')({ // 把px单位换算成rem单位
- rootValue: 192, // vant官方使用的是37.5
- minPixelValue: 4,
- unitPrecision: 3,
- // selectorBlackList: ['vant', 'mu'], // 忽略转换正则匹配项
- propList: ['*']
- })
- ]
- }
- }
- },
- devServer: {
- hot: true,
- port: devPort,
- open: true,
- noInfo: false,
- overlay: {
- warnings: true,
- errors: true,
- },
- proxy: {
- '/sgipad/duoduo-service/': {
- target: 'https://duoduoenv.sagacloud.cn',
- // target: 'http://192.168.0.47:52015',
- changeOrigin: true,
- pathRewrite: {
- '^/sgipad/duoduo-service': '/duoduo-service'
- }
- },
- "/sgipad/pad_mtime": {
- target: 'http://39.106.8.246:9091/',
- changeOrigin: true,
- pathRewrite: {
- '^/sgipad/pad_mtime': '/pad_mtime'
- }
- },
- '/sgipad/server/': {
- // target: 'https://duoduoenv.sagacloud.cn',
- target: 'http://sso.sagacloud.cn',
- changeOrigin: true,
- pathRewrite: {
- '^/sgipad/server': '/server'
- }
- },
- '/sgipad/mngserver/': {
- // target: 'https://duoduoenv.sagacloud.cn',
- target: 'http://mng.sagacloud.cn',
- changeOrigin: true,
- pathRewrite: {
- '^/sgipad/mngserver': '/server'
- }
- },
- '/sgipad/anon/': {
- // target: 'https://duoduoenv.sagacloud.cn',
- target: 'http://mng.sagacloud.cn',
- changeOrigin: true,
- pathRewrite: {
- '^/sgipad/anon': '/anon'
- }
- },
- '/sgipad/test/': {
- // target: 'https://duoduoenv.sagacloud.cn',
- target: 'http://192.168.88.6:52009', // 永琪
- // target: 'http://192.168.4.54:52009', // 小静
- // target: 'http://192.168.16.168:52015',
- changeOrigin: true,
- pathRewrite: {
- '^/sgipad/test': ''
- }
- },
- '/sgipad/test1/': {
- // target: 'https://duoduoenv.sagacloud.cn',
- target: 'http://192.168.0.65:52009',
- changeOrigin: true,
- pathRewrite: {
- '^/sgipad/test1': ''
- }
- },
- // '/api': {
- // target: 'http://api.sagacloud.cn',
- // changeOrigin: true,
- // pathRewrite: {
- // '^/api': ''
- // }
- // },
- // '/duoduo-service/': {
- // target: 'https://duoduoenv.sagacloud.cn',
- // changeOrigin: true,
- // pathRewrite: {
- // '^/duoduo-service': '/duoduo-service'
- // }
- // },
- // '/server/': {
- // target: 'https://duoduoenv.sagacloud.cn',
- // changeOrigin: true,
- // pathRewrite: {
- // '^/server': '/server'
- // }
- // },
- // '/object/': {
- // target: 'http://192.168.0.14:52010',
- // changeOrigin: true,
- // pathRewrite: {
- // '^/object': '/object'
- // }
- // },
- // '/mapServer/': {
- // target: 'http://192.168.0.14:52015',
- // changeOrigin: true,
- // pathRewrite: {
- // '^/mapServer': ''
- // }
- // }
- }
- },
- pluginOptions: {
- 'style-resources-loader': {
- preProcessor: 'scss',
- patterns: [
- path.resolve(__dirname, 'src/styles/_variables.scss'),
- path.resolve(__dirname, 'src/styles/_mixins.scss'),
- ]
- }
- },
- configureWebpack() {
- return {
- resolve: {
- alias: {
- '@': resolve('src'),
- '*': resolve(''),
- 'Assets': resolve('src/assets')
- }
- },
- module: {
- rules: [
- {
- test: /\.(json5?|ya?ml)$/, // target json, json5, yaml and yml files
- loader: '@intlify/vue-i18n-loader',
- include: [ // Use `Rule.include` to specify the files of locale messages to be pre-compiled
- path.resolve(__dirname, 'src/lang')
- ]
- },
- ],
- },
- plugins: isProduction ? [
- // new UglifyJsPlugin({
- // uglifyOptions: {
- // compress: {
- // drop_debugger: true,
- // drop_console: true, //生产环境自动删除console
- // },
- // warnings: false,
- // },
- // sourceMap: false,
- // parallel: true //使用多进程并行运行来提高构建速度。默认并发运行数:os.cpus().length - 1。
- // }),
- new webpack.ProvidePlugin({
- $: 'jquery',
- jQuery: 'jquery',
- 'windows.jQuery': 'jquery'
- }),
- // 配置压缩
- new CompressionPlugin({
- // test: new RegExp('\\.(' + productionGzipExtensions.join('|') + ')$'),
- threshold: 1024 * 10, // 30K
- minRatio: 0.8,
- algorithm: 'gzip', // 使用gzip压缩
- test: /\.js$|\.css$/, // 匹配文件名
- filename: '[path].gz[query]', // 压缩后的文件名(保持原文件名,后缀加.gz)
- deleteOriginalAssets: false
- }),
- new WebpackBar({
- name: title
- })
- ] : [new WebpackBar({
- name: title
- })],
- // externals: isProduction ? {
- // 'vue': 'Vue',
- // 'vuex': 'Vuex',
- // 'vant' : 'vant',
- // 'vue-router': 'VueRouter',
- // 'echarts': 'echarts'
- // } : {}
- }
- },
- chainWebpack: config => {
- config.optimization.minimizer('terser').tap((args) => {
- args[0].parallel = 4
- args[0].terserOptions.compress.warnings = true
- args[0].terserOptions.compress.drop_debugger = true
- args[0].terserOptions.compress.drop_console = true
- return args
- })
- config.module
- .rule('ts')
- .use('ts-loader')
- .tap(options => {
- options = merge(options, {
- transpileOnly: true,
- getCustomTransformers: () => ({
- before: [
- tsImportPluginFactory({
- libraryName: 'vant',
- libraryDirectory: 'es',
- style: true
- })
- ]
- }),
- compilerOptions: {
- module: 'es2015'
- }
- })
- return options
- })
- }
- }
|