как уменьшить размер файла вендора в веб-пакете (после того, как реализованы все методы) - PullRequest
0 голосов
/ 16 сентября 2018

я разработал приложение реагирования и веб-пакет я реализовал различные методы , чтобы уменьшить размер связки .like codespliting, динамического импорта , splitChunks, сжатие и uglifyJs и т. д., но по-прежнему размер моего поставщика составляет 570 кб .
Мой файл веб-пакета

const webpack = require('webpack');
const path = require('path');
const MiniCssExtractPlugin = require("mini-css-extract-plugin");
const HtmlWebpackPlugin = require('html-webpack-plugin');
const WebpackMd5Hash = require('webpack-md5-hash');
const CompressionPlugin = require('compression-webpack-plugin');
const VENDOR_LIBS =[
  'antd','axios','moment','rc-time-picker','react',
  'react-dom','react-ga','react-google-maps','react-loadable',
  'react-redux','react-router','react-router-dom','recompose','redux','redux-thunk'
];
const UglifyJsPlugin = require('uglifyjs-webpack-plugin');
const OptimizeCSSAssetsPlugin = require("optimize-css-assets-webpack-plugin");
module.exports = {
    entry:{
      vendor: VENDOR_LIBS,
      main: './src/app.js',
    },
  output: {
      path: path.join(__dirname, 'public'),
      filename: '[name].chunkhash.bundle.js',
      chunkFilename: '[name].chunkhash.bundle.js',
  },

  module: {
    rules: [
      {
        test: /\.js$/,
        exclude: /node_modules/,
        use: {
          loader: "babel-loader"
        }
      },
      {
        test: /\.s?css$/,
        use:  ['style-loader', MiniCssExtractPlugin.loader, 'css-loader', 'sass-loader']
    },{
        test: /\.(gif|svg|jpg|png|ttf|eot|woff(2)?)(\?[a-z0-9=&.]+)?$/,
        loader: "file-loader",
    }
    ]
  },
  plugins: [ 
    new MiniCssExtractPlugin({
      filename: 'style.[contenthash].css',
    }),
    new HtmlWebpackPlugin({
      inject: true,
      hash: true,
      template: './src/index.html',
      filename: 'index.html'
    }),
    new WebpackMd5Hash(),
    new CompressionPlugin({
      algorithm: 'gzip',
      test : /\.js$|\.css$|\.eot?.+$|\.ttf?.+$|\.woff?.+$|\.svg?.+$/,
      threshold: 10240,
      minRatio: 0.8
    }),
    new webpack.DefinePlugin({
        'process.env': {
            NODE_ENV: JSON.stringify('production')
        }
    }),
    new webpack.DefinePlugin({
      'process.env': {
        NODE_ENV: JSON.stringify('production')
      },
    })
  ],
  optimization: {
    splitChunks: {
      cacheGroups: {
        vendor: {
          test: /[\\/]node_modules[\\/]/,
                    name: 'vendors',
          chunks: 'all',
          minChunks: 2
        },
      }
    },
    runtimeChunk: true,
    minimizer: [
      new UglifyJsPlugin({
        cache: true,
        parallel: true,
        sourceMap: true,
        uglifyOptions: {
          compress: {
            inline: false
          }
        }
      }),
      new OptimizeCSSAssetsPlugin({})
    ],
  },
};

На самом деле мое веб-приложение большую часть времени открыто только для мобильных устройств, и большинство из них являются сетями 3G, поэтому на это уходит немного больше времени. Поэтому есть ли способ уменьшить размер файла vendor.js.
я уже внедрил brotli алгоритм на стороне сервера, поэтому теперь он составляет 440 КБ.
я хочу уменьшить до 250 кб

1 Ответ

0 голосов
/ 20 сентября 2018

Рассматривали ли вы "пакет-загрузчик"? Этот модуль поможет вам разбить критический JS. Естественно, это потребует некоторого рефакторинга / архитектуры вашего основного: './src/app.js' Ваш модуль должен быть загружен асинхронно.

https://github.com/webpack-contrib/bundle-loader

Также есть несколько автоматизаций, которые webpack-4 делает автоматически для вас, если вы сообщите режим: «production», тогда вы можете избежать многих ваших плагинов и иметь более чистый файл конфигурации.

...