通常来说,我们的代码都可以至少简单区分成业务代码和第三方库。如果不做处理,每次构建时都需要把所有的代码重新构建一次,耗费大量的时间。然后大部分情况下,很多第三方库的代码并不会发生变更(除非是版本升级),因此Webpack 打包时,对于一些不经常更新的第三方库,比如 vue、vue-router,vuex、lodash等,希望能和业务代码分离开,Webpack社区有两种方案CommonsChunkPluginDLLPlugin.

对于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的更多相关文章

  1. webpack性能优化——DLL

    Webpack性能优化的方式有很多种,本文之所以将 dll 单独讲解,是因为 dll 是一种最简单粗暴并且极其有效的优化方式. 在通常的打包过程中,你所引用的诸如:jquery.bootstrap.r ...

  2. webpack 性能优化 dll 分包

    webpack 性能优化 dll 分包 html-webpack-externals-plugin DLLPlugin https://www.webpackjs.com/configuration/ ...

  3. 常见 Web 性能优化方式

    这篇文章是我阅读 Web Performance 101 之后的进行的粗糙的翻译作为笔记,英语还行的童鞋可以直接看原文. 这篇文章主要介绍了现代 web 加载性能(注意不涉及代码算法等),学习为什么加 ...

  4. webpack 性能优化小结

    背景 如今前端工程化的概念早已经深入人心,选择一款合适的编译和资源管理工具已经成为了所有前端工程中的标配,而在诸多的构建工具中,webpack以其丰富的功能和灵活的配置而深受业内吹捧,逐步取代了gru ...

  5. webpack性能优化

    Webpack优化打包速度以及性能优化 1.跟上技术的迭代(Node.Npm.Yarn) 2.在尽可能少的模块上应用loader 3.Plugin尽可能精简并确保可靠 4.resolve参数合理配置 ...

  6. Webpack 性能优化 (一)(使用别名做重定向)

    前言 Webpack 是 OneAPM 前端技术栈中非常重要的一部分.它非常好用,假设你还不了解它,建议你阅读这篇Webpack 入门指迷,在 OneAPM 我们用它完毕静态资源打包.ES6 代码的转 ...

  7. webpack性能优化-实战

    题外话:年初项目重构上线,项目技术栈使用vue+webpack,测试执行整个打包流程需要10分钟,同时又因涉及三个渠道,部署好环境就需半个小时,这严重延误了上线进度,因此提高webpack构建效率,成 ...

  8. react 实用的性能优化方式

    react 组件渲染分为初始化渲染和更新渲染,当我们更新某个组件的时候,只是想关键路径上组件的render,但react的默认做法是调用所以组件的reder,再生成虚拟dom进行对比,如不变则不进行更 ...

  9. webpack 性能优化 -- 待续

    文章 这篇文章挺不错的, 各方面优化都提到了, 有空研究下 文章 这个文章提出 , 增量打包用 webpack-watch 会让你打包速度飞快,  react不参与打包, 不require, 而是放在 ...

  10. Attribute操作的性能优化方式

    Attribute是.NET平台上提供的一种元编程能力,可以通过标记的方式来修饰各种成员.无论是组件设计,语言之间互通,还是最普通的框架使 用,现在已经都离不开Attribute了.迫于Attribu ...

随机推荐

  1. AIRIOT答疑第7期|如何快速提升物联网项目交付速度?

    平台+模板,套上就能用!贼拉快! AIRIOT提供物联网低代码平台+多套行业案例模板,针对于有明确项目的服务商,用平台已经配置好的节点数.功能模块.流程,直接上手干项目! AIRIOT解答: 多套物联 ...

  2. 5款.NET开源、免费、功能强大的图表库

    LiveCharts2 LiveCharts2是一个.NET开源(MIT License).简单.灵活.交互式且功能强大的.NET图表.地图和仪表,现在几乎可以在任何地方运行如:Maui.Uno Pl ...

  3. 【论文笔记】R-CNN系列之代码实现

    代码源码 前情回顾:[论文笔记]R-CNN系列之论文理解 整体架构 由三部分组成 (1)提取特征的卷积网络extractor (2)输入特征获得建议框rois的rpn网络 (3)传入rois和特征图, ...

  4. MyBatis实现MySQL表字段及结构的自动增删

    前言 在开发过程中,总会涉及到数据库表结构字段的增加或者删除,或者是索引的增加和减少,这个时候能把修改表结构字段这些工作都交给程序来进行,那能大大方便开发.正好有一个现成的工具可以在springboo ...

  5. 自用电脑+外网开放+SSL认证(纯免费)

    背景: 本文的目的主要是为了方便大家测试,不过有条件的情况下没必要学习了.主要是给那些没有服务器,公司也不给ssl认证的开发测试人员的一种方案:就像题目所说的那样. 纯免费,纯免费的话是有学习成本的, ...

  6. xhs全参xs,xt,xscommon逆向分析

    声明 本文章中所有内容仅供学习交流,抓包内容.敏感网址.数据接口均已做脱敏处理,严禁用于商业用途和非法用途,否则由此产生的一切后果均与作者无关,若有侵权,请联系我立即删除! 目标网站 aHR0cHM6 ...

  7. 微信支付(付款码支付,条码支付,刷卡支付)左上角LOGO显示

    微信支付(付款码支付,条码支付,刷卡支付)左上角LOGO显示 如果你上送的sub_appid 公众号(小程序),优先显示你公众号(小程序)的LOGO,如果你的公众号(小程序)未设置LOGO,会显示上游 ...

  8. “Newtonsoft.Json”已拥有为“Microsoft.CSharp”定义的依赖项。

    安装较低版本的Newtonsoft.Json: Newtonsoft.Json官网:https://www.nuget.org/packages/Newtonsoft.Json/ Install-Pa ...

  9. 使用 OpenTelemetry 构建可观测性 05 - 传播和行李(Propagation & Baggage)

    我们开发的应用程序可能具有不同的形态和架构:有些是单体应用,有些是微服务.为单体应用程序添加遥测数据相对来说简单,因为所有数据都在同一进程中.然而对于微服务应用程序,情况可能会更具挑战性. 通常,分布 ...

  10. 项目管理--PMBOK 读书笔记(6)【项目进度管理】

    1.紧前关系绘图法(PDM): 2.三点估算(PERT): 最可能时间(Tm).最乐观时间(To)和 最悲观时间(Tp): 三角分布: 平均估算值=(Tm+To+Tp)/3: 3.估算方法对比及应用场 ...