• webpack 打包文件体积过大解决方案(code splitting)


    优化对比 :

      未优化前:index.html引入一个main.js文件,体积2M以上。

      优化后入:index.html引入main.js、commons.js、charts.js、other.js。以达到将main.js平分目的。每个文件控制300k以内.(如果高兴100k也没问题)

    用到的一堆库及工具:

    vue、webpack、babel、highcharts、echarts、jquery、html2canvas******此去省略若干m代码

    问题:

      开发环境用webpack后发现单个js文件5m。

      生产环境借助vue-cli的webpack配置,减少到2m。

    解决方案:

      搜索各种解决方案:require.ensure、require依赖、多entry、commonsChunkPlugin****此去省力若干方案

    网络类似下边这种上解决方案太多了,但是都达不到预期效果

    entry:{  
        main:'xxx.js',
          chunks:['c1', 'c2'],
         commons:['jquery', 'highcharts', 'echarts','d3', 'xxxxx.js']      
    }
    plugins:{
    new commonsChunkPlugin({
    name:'commons',
    minChunks:2
    })        
    }

    最优解决方案:

    entry:{  
        main:'xxx.js'
    }
    
    plugins:{
       new commonsChunkPlugin({
        name:'commons',
        minChunks:function(module){
          //  下边return参考的vue-cli配置
          // any required modules inside node_modules are extracted to vendor
          return (
              module.resource &&
              /.js$/.test(module.resource) &&
              module.resource.indexOf(
                path.join(__dirname, '../node_modules')
              ) === 0
            )
       }
    }) ,
    // 以下才是关键
    new commonsChunkPlugin({
        name:'charts',
        chunks:['commons']  
        minChunks:function(module){
          return (
              module.resource &&
              /.js$/.test(module.resource) &&
              module.resource.indexOf(
                path.join(__dirname, '../node_modules')
              ) === 0 && ['jquery.js', 'highcharts.js','echarts'].indexOf( module.resource.substr(module.resource.lastIndexOf('/')+1).toLowerCase() ) != -1
            )
       }
    })  
    // 如果愿意,可以再new 一个commonsChunkPlugin }

    以上代码打包出来的结果main.js 、commons.js、charts.js  

  • 相关阅读:
    vector详解
    浅谈 莫斯电码&栅栏密码
    牛牛的BRD迷宫2 构造+思维
    Codeforces Round #409 C. Voltage Keepsake(二分+思维)
    hdu 2609 How many(最小表示法)
    hdu 4513(Manacher)
    codeforces 486 E. LIS of Sequence(dp)
    codeforces 486 D. Valid Sets(树形dp)
    hdu3746(kmp最小循环节)
    poj 2406 Power Strings(kmp next的应用)
  • 原文地址:https://www.cnblogs.com/nuoku/p/6057024.html
Copyright © 2020-2023  润新知