webpack性能优化方式之dll--- webpack.dll.config.js
通常来说,我们的代码都可以至少简单区分成业务代码和第三方库。如果不做处理,每次构建时都需要把所有的代码重新构建一次,耗费大量的时间。然后大部分情况下,很多第三方库的代码并不会发生变更(除非是版本升级),因此Webpack 打包时,对于一些不经常更新的第三方库,比如 vue、vue-router,vuex、lodash等,希望能和业务代码分离开,Webpack社区有两种方案CommonsChunkPlugin和DLLPlugin.
对于CommonsChunkPluginwebpack每次打包实际还是需要去处理这些第三方库,只是打包完之后,能把第三方库和我们自己的代码分开(此处先不做说明)。而 DLLPlugin则是能把第三方代码完全分离开,即每次只打包项目自身的代码。
DLLPlugin:  DLL(Dynamic Link Library)文件为动态链接库文件,是一种最简单粗暴并且极其有效的优化方式,使用DLLPlugin,可以把构建过程分成dlI构建过程和主构建过程(实质也就是如此)。所以对于用这种方式打包的项目,需要额外新建一个配置文件,一般会有以下两个配置文件:webpack.config.js、webpack.dll.config.js
webpack.dll.configjs 简单配置: 打包需要分离到动态库的模块
const path =require('path')
const webpack=require('webpack')
var vendors = [
  "@antv/g6",
  "axios",
  "echarts",
  "vue",
  "vue-router",
  "vuex"
}
module.exports = {
 entry: {
  vendor:vendors
  },
  output: {
    path: path.join(__dirname, "/dist"),
    filename: "Dll.js",
    library: "[name]_[hash]"
  }
  plugins:[
    new webpack.DIlPlugin({    //webpack内置的插件,不需要额外安装
      path: path.join(__dirname,"/dist","manifest.json"),
      //动态链接库的全局变量名称,需要和 output.library中保持一致
      //该字段的值也就是输出的 manifest.json文件中 name字段的值
      name: "[name]_[hash]",
      context:__dirname
    })
  ]
}
webpack.configjs: 在主构建配置文件中使用动态库文件,manifest文件给主构建流程作为查找dll的依据: DllReferencePlugin去manifestjson文件读取name值,作为从全局变量中获取动态链接库,内容时的全局变量名,因此:在webpack.dll.config.js文件中,DllPlugin 中的name 参数必须和 output.library中保持一致。
  plugins:[
    new webpack.DIlReferencePlugin({  // webpack内置的插件,不需要额外安装 使用了哪些动态链接库
      context: __dirname
      manifest: require('./dist/manifestjson')
    })
  ]
package.json 中增加scripts 指令配置: 此命令将依赖包合并打包为一个名为dll.js的静态资源包,同时生成一个manifest.json文件方便对 dll.js 中的模块进行引用,manifest.json 给各个模块赋予 id 以便引用。
  "scripts":{
    "dllbuild": "webpack --mode  production  --config  webpack.dll.config.js",
    "dlldev": "webpack --mode  development --config  webpack.dll.config.js"
  }
最后在index.html中引入: 在入口文件引入dll文件,生成的dll暴露出的是全局函数,因此还需要在入口文件里面引入对应的 dll文件。
  <script src="./dist/Dll.js">/script><!--注意路径 -->
其他补充:上述用法存在一些不便之处,如在webpack.config.js中要明确指出对应的 manifest.json文件。还有当依赖升级DLL需要更新时,或者加入新的第三方库,都需要手动编译一次。
Dll Link Plugin,用于简化生成 webpack DLL的插件。基于 DIlReferencePlugin。
npm install dll-link-webpack-plugin -D
在webpackconfigjs配置文件中,用DIlLinkPlugin替换掉DIIReferencePlugin。然后运行webpack --config webpack.config.js,会自动生成DLL文件,需要更新的时候,也会自动更新
var DllLinkPlugin=require("dll-link- webpack-plugin");
module.exports={
// ...
  plugins: [
    new DllLinkPlugin({
      config: require("webpack.dll.config.js")
    })
  ]
};
总结DLL的作用:
1.分离代码,业务代码和第三方模块可以被打包到不同的文件里,避免打包出单个文件太大,不利于调试,
2.将单个大文件拆成多个小文件,一定情况下有利于加载(不超出浏览器一次性请求的文件数情况下,并行下载肯定比串行快)
3.提升构建速度。第三方库没有变更时,由于只构建业务代码,相比全部重新构建要快的多。
webpack性能优化方式之dll--- webpack.dll.config.js的更多相关文章
- webpack性能优化——DLL
		
Webpack性能优化的方式有很多种,本文之所以将 dll 单独讲解,是因为 dll 是一种最简单粗暴并且极其有效的优化方式. 在通常的打包过程中,你所引用的诸如:jquery.bootstrap.r ...
 - webpack 性能优化 dll 分包
		
webpack 性能优化 dll 分包 html-webpack-externals-plugin DLLPlugin https://www.webpackjs.com/configuration/ ...
 - 常见 Web 性能优化方式
		
这篇文章是我阅读 Web Performance 101 之后的进行的粗糙的翻译作为笔记,英语还行的童鞋可以直接看原文. 这篇文章主要介绍了现代 web 加载性能(注意不涉及代码算法等),学习为什么加 ...
 - webpack 性能优化小结
		
背景 如今前端工程化的概念早已经深入人心,选择一款合适的编译和资源管理工具已经成为了所有前端工程中的标配,而在诸多的构建工具中,webpack以其丰富的功能和灵活的配置而深受业内吹捧,逐步取代了gru ...
 - webpack性能优化
		
Webpack优化打包速度以及性能优化 1.跟上技术的迭代(Node.Npm.Yarn) 2.在尽可能少的模块上应用loader 3.Plugin尽可能精简并确保可靠 4.resolve参数合理配置 ...
 - Webpack 性能优化 (一)(使用别名做重定向)
		
前言 Webpack 是 OneAPM 前端技术栈中非常重要的一部分.它非常好用,假设你还不了解它,建议你阅读这篇Webpack 入门指迷,在 OneAPM 我们用它完毕静态资源打包.ES6 代码的转 ...
 - webpack性能优化-实战
		
题外话:年初项目重构上线,项目技术栈使用vue+webpack,测试执行整个打包流程需要10分钟,同时又因涉及三个渠道,部署好环境就需半个小时,这严重延误了上线进度,因此提高webpack构建效率,成 ...
 - react 实用的性能优化方式
		
react 组件渲染分为初始化渲染和更新渲染,当我们更新某个组件的时候,只是想关键路径上组件的render,但react的默认做法是调用所以组件的reder,再生成虚拟dom进行对比,如不变则不进行更 ...
 - webpack 性能优化  -- 待续
		
文章 这篇文章挺不错的, 各方面优化都提到了, 有空研究下 文章 这个文章提出 , 增量打包用 webpack-watch 会让你打包速度飞快, react不参与打包, 不require, 而是放在 ...
 - Attribute操作的性能优化方式
		
Attribute是.NET平台上提供的一种元编程能力,可以通过标记的方式来修饰各种成员.无论是组件设计,语言之间互通,还是最普通的框架使 用,现在已经都离不开Attribute了.迫于Attribu ...
 
随机推荐
- 编译mmdetection3d时,无root权限下为虚拟环境单独创建CUDA版本
			
在跑一些深度学习代码的时候,如果需要使用mmdetection3d框架,下载的pytorch的cudatoolkit最好需要和本机的cuda版本是一样的,即输入nvcc -V命令后显示的版本一样. 但 ...
 - 搭建一套完整的ELK系统
			
ELK日志收集系统介绍 一 简单介绍 ELK部署搭建有很多成型的方案,这里推荐一种比较中规中矩的方案,它整合了logstash比较消耗资源以及当服务端临时宕机的时候出现数据丢失的问题,主要由fi ...
 - Java RMI遇到的Connection refused to Host: 127.x.x.x/192.x.x.x/10.x.x.x问题解决方法
			
问题故障解决记录 -- Java RMI Connection refused to host: x.x.x.x .... 在学习JavaRMI时,我遇到了以下情况 问题原因:可能大家的host是10 ...
 - mews/captcha 验证码组件
			
/** * 图像验证码 */ public function captcha(CaptchaBridge $captcha, $type = 'default') { $api_captcha = $ ...
 - MyBatis数据源模块源码分析
			
数据源对象是比较复杂的对象,其创建过程相对比较复杂,对于 MyBatis 创建数据源,具体来讲有如下难点: MyBatis 不但要能集成第三方的数据源组件,自身也提供了数据源的实现: 数据源的初始化参 ...
 - go  goroutine pool设计
			
推荐一遍由浅入深简绍goroutine pool设计的方案.https://strikefreedom.top/high-performance-implementation-of-goroutine ...
 - FFmpeg Batch AV Converter  2.2.2 官方版
			
基本简介 FFmpeg Batch AV Converter官方版是一款Windows FFmpeg用户的前端程序,FFmpeg Batch AV Converter最新版允许使用FFmpeg命令行的 ...
 - .NET6之MiniAPI(九):基于角色的身份验证和授权
			
身份验证是这样一个过程:由用户提供凭据,然后将其与存储在操作系统.数据库.应用或资源中的凭据进行比较. 在授权过程中,如果凭据匹配,则用户身份验证成功,可执行已向其授权的操作. 授权指判断允许用户执行 ...
 - Hugging Face x LangChain: 全新 LangChain 合作伙伴包
			
我们很高兴官宣发布 langchain_huggingface ,这是一个由 Hugging Face 和 LangChain 共同维护的 LangChain 合作伙伴包.这个新的 Python 包旨 ...
 - SQL KEEP 窗口函数等价改写案例
			
一哥们出条sql题给我玩,将下面sql改成不使用keep分析函数的写法. select deptno, ename, sal, hiredate, min(sal) keep(dense_rank f ...