zoukankan      html  css  js  c++  java
  • webpack实践之DLLPlugin 和 DLLReferencePlugin

    DLLPlugin 和 DLLReferencePlugin的使用

    DLLPlugin 和 DLLReferencePlugin 用某种方法实现了拆分 bundles,同时还大大提升了构建的速度。

    1.首先build文件夹添加----webpack.dll.config.js:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    var path = require("path");
    var webpack = require("webpack");
    module.exports = {
     // 要打包的模块的数组
     entry: {
      vendor: ['vue/dist/vue.esm.js','vue-router']
     },
     output: {
      path: path.join(__dirname, '../static/js'), // 打包后文件输出的位置
      filename: '[name].dll.js',// vendor.dll.js中暴露出的全局变量名。
      library: '[name]_library' // 与webpack.DllPlugin中的`name: '[name]_library',`保持一致。
     },
     plugins: [
      new webpack.DllPlugin({
       path: path.join(__dirname, '.', '[name]-manifest.json'),
       name: '[name]_library',
       context: __dirname
      }),
     ]
    };

    2.在package.json的scripts里加上:

    "dll": "webpack --config build/webpack.dll.config.js",

    3.运行npm run dll 在static/js下生成vendor-manifest.json;

     4.在build/webpack.base.conf.js里加上:

    1
    2
    3
    4
    5
    6
    7
    // 添加DllReferencePlugin插件
     plugins: [
      new webpack.DllReferencePlugin({
       context: __dirname,
       manifest: require('./vendor-manifest.json')
      })
     ],

    5.然后在index.html中引入vendor.dll.js:

    1
    2
    <div id="app"></div>
    <script src="./static/js/vendor.dll.js"></script>

    至此,配置之后的:

     可以看到npm run build后的时间大幅度减少,在dist打包体积上也比之前的小。在项目优化中,可以很大程度上加快项目的构建速度和减少项目的打包体积。

  • 相关阅读:
    Linux下挂载新硬盘
    远程编写+调试服务器上的Python程序
    记一次CUDA编程任务
    CUDA核函数调用基础数学API的一个奇葩情况
    Python多线程常用包对比
    Python threadpool传递参数
    代码生成器
    从移动优先到离线优先(三)
    从移动优先到离线优先(二)
    从移动优先到离线优先(一)
  • 原文地址:https://www.cnblogs.com/ygunoil/p/13032011.html
Copyright © 2011-2022 走看看