Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >webpack DLL 动态链接库

webpack DLL 动态链接库

作者头像
Ewall
发布于 2020-12-01 02:27:08
发布于 2020-12-01 02:27:08
2.4K00
代码可运行
举报
文章被收录于专栏:vue学习vue学习
运行总次数:0
代码可运行

项目地址:https://github.com/Ewall1106/webpack-demo

是什么?

许多应用程序并不是一个完整的可执行文件,它们被分割成一些相对独立的动态链接库,即 DLL 文件,放置于系统中。当我们执行某一个程序时,相应的 DLL 文件就会被调用。一个应用程序可使用多个 DLL 文件,一个 DLL 文件也可能被不同的应用程序使用,这样的 DLL 文件被称为共享 DLL 文件。— 百度百科

  • 翻译一下,在 webpack 中的动态链接库就是:由于每次更改了内容 webpack 都会自动重新编译打包,如果我们把用到的如 reactjquery 这些外部库抽离出去,改变文件的时候不让 webpack 重新打包这部分文件,直接引用,那么重新编译打包的速度就会快很多,这样我们开发的效率也会提升。
  • 再翻译一下,所谓动态链接库就是帮你提升开发效率的,使 webpack 在重编译的时候能打包更快。
  • webpack 中实现 DLL 主要依赖两个插件 webpack.DllReferencePluginwebpack.DllPlugin,先记好这两个即可。

安装

  • 还是从头开始,先新建一个文件初始化一下打包的基本配置。
  • 我们以 react 这个库为例,假设我们要把 react 做为动态链接库,让其不需要每次重新编译。
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
# 初始化
$ npm init -y
# 安装一些基础的包
$ sudo npm i webpack webpack-cli react react-dom html-webpack-plugin webpack-dev-server clean-webpack-plugin babel-loader @babel/core @babel/preset-env @babel/preset-react --save-dev
  • 接下来就是一些基本的 webpack.config.js 配置了,这些前面文章都已经就逐步详细介绍了,这里就一笔带过了,本篇文章只重点说明 DLL 怎么配置的。
  • 然后我们在入口文件中随便写几行代码,跑起来后我们就可以看到 hello world 跃然于页面上了。
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import React from 'react';
import ReactDOM from 'react-dom';

ReactDOM.render(<div>hello world</div>, document.getElementById('app'));

打包 React

  • 我们要把 react 做为动态链接库,所以我们单独为其新建一个打包配置文件 - webpack.react.js
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
const path = require('path');
const webpack = require('webpack');

module.exports = {
  mode: 'development',

  entry: {
    react: ['react', 'react-dom'],
  },

  output: {
    filename: '_dll_[name].js',
    path: path.resolve(__dirname, './dist'),
    library: '_dll_[name]',
    libraryTarget: 'umd',
  },

  plugins: [
    new webpack.DllPlugin({
      name: '_dll_[name]',
      path: path.resolve(__dirname, 'dist', 'manifest.json'),
    }),
  ],
};
  • 上面的配置重点是 plugins 插件中配合的 webpack.DllPlugin 这个插件,它会生成一个名为 manifest.json 的文件,你可以理解为就是一张表,我们可以定义依赖,也就是说待会我们用到了 react 的时候,告诉 webpack 就直接在这个文件里找,别重复打包编译 react 了。
  • 打包一下,我们就可以看到 dist 文件夹中出现了打包后的 react 文件和 manifest.json 依赖表了。
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
$ npx webpack --config webpack.react.js
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
/dist
+ _dll_react.js
+ manifest.json

设置依赖

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
module.exports = {
  // ...
  // ...
  plugins: [
    // 当使用react的使用,先去这个表里面找
    new webpack.DllReferencePlugin({
      manifest: path.resolve(__dirname, 'dist', 'manifest.json'),
    }),
  ],
};
  • 这个就是告诉 webpack,当我们页面中引入使用了 react 这个库的时候,直接去 manifest.json 里去找,然后引用打包好的 _dll_react.js 就行了。

小结

  • 对比这两种方式,基本快了了 10ms 左右,如果你的项目很大,将一些 react、vue、jquery 这些库都进行 DLL 配置后,那么开发效率提高还是可观的。
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
./src/index.js 172 bytes [built][code generated]
webpack 5.4.0 compiled successfully in 56 ms

// 使用DLL配置react库后:

./src/index.js 172 bytes [built][code generated]
webpack 5.4.0 compiled successfully in 41 ms
  • DLL 这个名称很吓人,但是其实配置起来并不难,主要就是利用了 webpack 自己实现的两个插件,就简单的说到这里。
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
webpack性能优化之externals 与 DllPlugin
externals和DllPlugin都是为了分离模块诞生,通过他们可以将一些第三方模块抽离出来,打包的时候不需将某些三方库一起打包如vue、vue-router
切图仔
2022/09/08
9310
webpack性能优化之externals 与 DllPlugin
辛辛苦苦学会的 webpack dll 配置,可能已经过时了
如果大家看过一些 webpack 优化的文章,一定会出现 dll 动态链接库。它以配置之复杂让众多初学者记忆犹新。
卤代烃
2020/10/27
1.1K0
辛辛苦苦学会的 webpack dll 配置,可能已经过时了
webpack打包优化面试_什么是webpack
3. 正常实现es6转换es5 基本实现效果查看webpack官网达到实现效果
全栈程序员站长
2022/11/03
9690
前端性能优化篇一:webpack性能优化
当我们不用cli,而是自己搭建项目架子的时候,会用到webpack构建我们的项目,在用webpack构建项目的时候,过长的打包编译时间和庞大冗余的代码会让我们感到头疼。所以优化webpack性能成为了不可或缺的一部分。下面我们一起来探讨webpack性能优化细节。
用户6835371
2021/06/01
2.3K0
前端性能优化篇一:webpack性能优化
webpack的进阶使用
Webpack 是一个模块打包器,可以将多个模块打包成一个或多个文件。除了基本的打包功能外,Webpack 还提供了很多高级功能,可以优化打包结果、提高构建速度等。在本文中,我们将介绍 Webpack 的一些进阶使用技巧,并提供相应的代码示例。
世间万物皆对象
2024/03/20
1200
[打包优化]Webpack DLL
原创不易,未经作者允许禁止转载!! 认识DLL库 什么是DLL DLL全称是动态链接库(Dynamic Link Library),是为软件在Windows中实现共享函数库的一种实现方式; 那么webpack中也有内置DLL的功能,它指的是可以将可以共享,并且不经常改变的代码,抽取成一个共享的库; 这个库在之后编译的过程中,会被引入到其他项目的代码中,减少的打包的时间; DDL库的使用分为两步: 第一步:打包一个DLL库; 第二步:项目中引入DLL库 DLL打包 webpack内置DllPlugin帮助生
前端LeBron
2021/12/08
1.8K0
webpack调优总结
webpack 的出现为前端开发带来翻天覆地的变化,无论你是用 React,Vue 还是 Angular,webpack 都是主流的构建工具。我们每天都跟它打交道,但却很少主动去了解它,就像写字楼里的礼仪小姐姐,既熟悉又陌生。随着项目复杂度的上升,打包构建的时间会越来越长。终于有一天,你发现npm run dev后,去泡个茶,上了个厕所,跟同事 bb 一轮后回到座位,项目还没构建完的时候,你就会下定决心好好了解下这个熟悉的陌生人。
Dickensl
2022/06/14
2600
webpack的高阶使用
Webpack 是一款强大的模块打包工具,广泛应用于现代前端开发中。本文将从以下几个方面讨论 Webpack 的高阶使用方法:
世间万物皆对象
2024/03/20
1380
webpack实战——打包优化【中】
上篇从多线程打包和缩小打包作用域两个方面入手,对webpack打包层面做出优化。本篇描述从动态链接库思想方面继续深入探究打包层面的深度优化。
流眸
2020/11/06
9300
记一次webpack打包优化
未进行打包优化的痛点:   随着项目的不断扩大,引入的第三方库会越来越多,我们每次build的时候会对所有的文件进行打包,耗时必定很长,不利于日常开发。 解决思路:   第三方库我们只是引入到项目里来,一般不会经常性的去修改源码,一般都是在src目录下编写业务代码,因此可以把第三方依赖和src分开打包。   每次build的时候我们只需要把之前build好的第三方依赖文件引入到项目中即可,避免了我们每次build的时候都会build第三方依赖。   当第三方依赖发生改变的时候我们只需要把第三方依赖再buil
大当家
2018/06/28
1.4K1
Webpack打包构建太慢了?试试几个方法
webpack支持监听模式,此时需要重新编译时就可以进行增量构建,增量构建是很快的,基本不到一秒或几秒之内就能重新编译好
书童小二
2018/09/03
5.2K0
Webpack打包构建太慢了?试试几个方法
性能优化篇---Webpack构建速度优化
const Jarvis = require("webpack-jarvis"); plugins: [ new Jarvis({ watchOnly: false, port: 3001 // optional: set a port }) ];
keyWords
2019/03/20
2.3K0
性能优化篇---Webpack构建速度优化
webpack优化解决项目体积大、打包时间长、刷新时间长问题!
在大家的日常开发中,特别是开发大型项目,大家有没有每次打包想要骂娘的冲动!反正我是很痛苦,每次打包20分钟起,这漫长的等待时间,让人非常焦虑,遇见一些特殊问题(比如测试微信分享),必须要打包部署,看效果,你会发现,一天时间全部浪费在打包上,真所谓改代码两分钟,打包代码两小时,于是闲暇之余,研究了一下webpck打包机制,并且通过几个小插件和一些技巧成功的减少公司项目的打包时间,虽然打包时间没有断崖式的减少,但是能少一分钟,是一分钟吧,下面我们一起来研究一下webpack的性能优化,以及体积优化!
用户7413032
2020/06/11
11.1K0
webpack优化解决项目体积大、打包时间长、刷新时间长问题!
趁webpack5还没出,先升级成webpack4吧
webpack4升级完全指南 webpack4 changelog React 16 加载优化性能
书童小二
2018/09/03
1.6K0
趁webpack5还没出,先升级成webpack4吧
加速 Webpack
作者:吴浩麟 https://www.ibm.com/developerworks/cn/web/wa-lo-expedite-webpack/index.html Web 应用日益复杂,相关开发技术也百花齐放,这对前端构建工具提出了更高的要求。 Webpack 从众多构建工具中脱颖而出成为目前最流行的构建工具,几乎成为目前前端开发里的必备工具之一。 大多数人在使用 Webpack 的过程中都会遇到构建速度慢的问题,在项目大时显得尤为突出,这极大的影响了我们的开发体验,降低了我们的开发效率。 本文将传授你一
企鹅号小编
2018/02/06
2.1K0
webpack dll 提升构建速度
DLL,动态链接库(Dynamic Link Library 或者 Dynamic-link Library),由微软公司提出。目的是为了节约应用程序所需的磁盘和内存空间。
奋飛
2023/03/09
1.2K0
webpack dll 提升构建速度
优化Webpack构建性能的几点建议
Webpack 作为目前最流行的前端构建工具之一,在 vue/react 等 Framework 的生态圈中都占据重要地位。在开发现代 Web 应用的过程中,Webpack 和我们的开发过程和发布过程都息息相关,如何改善 Webpack 构建打包的性能也关系到我们开发和发布部署的效率。 以下是一些关于优化 Webpack 构建性能的几点建议: 一、选择合适的 Devtool 版本 ​webpack 的 devtool 配置,决定了在构建过程中怎样生成 sourceMap 文件。通常来说eval的性能最高,但
葡萄城控件
2018/06/21
7750
一波webpack
1.什么是WebPack,为什么要使用它? WebPack可以看做是模块打包机:它做的事情是,分析你的项目结构,找到JavaScript模块以及其它的一些浏览器不能直接运行的拓展语言(Scss,TypeScript等),并将其转换和打包为合适的格式供浏览器使用。 为什么要使用webpack:因为源码无法直接在浏览器上运行,必须通过转码后才能运行。 ---- 2.常见的构建工具 目前的构建工具: Npm Script Grunt Gulp Fis3 webpack Rollup 构建工具需要做哪些事: 代码
pitaojin
2018/05/24
8470
vue-cli webpack2项目打包优化
减小文件搜索范围 配置 resolve.modules Webpack的resolve.modules配置模块库(即 node_modules)所在的位置,在 js 里出现 import 'vue' 这样不是相对、也不是绝对路径的写法时,会去 node_modules 目录下找。但是默认的配置,会采用向上递归搜索的方式去寻找,但通常项目目录里只有一个node_modules,且是在项目根目录,为了减少搜索范围,可以直接写明 node_modules 的全路径;同样,对于别名(`alias)的配置,亦当如此:
mcq
2018/06/20
1.4K0
优化 Webpack 构建性能的几点建议
来源:葡萄城控件 http://www.cnblogs.com/powertoolsteam/p/Webpack.html Webpack 作为目前最流行的前端构建工具之一,在 vue/react 等 Framework 的生态圈中都占据重要地位。在开发现代 Web 应用的过程中,Webpack 和我们的开发过程和发布过程都息息相关,如何改善 Webpack 构建打包的性能也关系到我们开发和发布部署的效率。 以下是一些关于优化 Webpack 构建性能的几点建议: 一、选择合适的 Devtool 版本 we
企鹅号小编
2018/01/12
7390
优化 Webpack 构建性能的几点建议
相关推荐
webpack性能优化之externals 与 DllPlugin
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验