Webpack 核心知识有哪些?,web前端入门宝典

本文详细介绍了如何在Webpack中使用异步Loader,展示了Plugin的实现原理,包括apply函数和compilerhooks的使用。此外,还探讨了性能优化策略,如Loader配置优化、缓存利用和代码压缩,以及如何利用Tapable和thread-loader进行多线程处理。
摘要由CSDN通过智能技术生成

// 1.调用this.async() 告诉webpack这是一个异步loader,需要等待 asyncCallback 回调之后再进行下一个loader处理

// 2.this.async 返回异步回调,调用表示异步loader处理结束

const asyncCallback = this.async();

const timer = setInterval(() => {

console.log(时间已经过去${count++}秒);

}, 1000);

// 异步操作

setTimeout(() => {

clearInterval(timer);

asyncCallback(null, source);

}, 3200);

};

4. Plugin


在webpack编译整个生命周期的特定节点执行特定功能

实现要点:

  • 一个命名JS函数或者JS类

  • 在prototype上定义一个apply方法(供webpack调用,并且在调用时注入 compiler 对象)

  • 在 apply 函数中需要有通过 compiler 对象挂载的 webpack 事件钩子(钩子函数中能拿到当前编译的 compilation 对象)

  • 处理 webpack 内部实例的特定数据

  • 功能完成后调用 webpack 提供的回调

基本模型:

// 1、Plugin名称

const MY_PLUGIN_NAME = “MyBasicPlugin”;

class MyBasicPlugin {

// 2、在构造函数中获取插件配置项

constructor(option) {

this.option = option;

}

// 3、在原型对象上定义一个apply函数供webpack调用

apply(compiler) {

// 4、注册webpack事件监听函数

compiler.hooks.emit.tapAsync(

MY_PLUGIN_NAME,

(compilation, asyncCallback) => {

// 5、操作Or改变compilation内部数据

console.log(compilation);

console.log(“当前阶段 ======> 编译完成,即将输出到output目录”);

// 6、如果是异步钩子,结束后需要执行异步回调

asyncCallback();

}

);

}

}

// 7、模块导出

module.exports = MyBasicPlugin;

实现一个plugin,功能是在dist目录自动生成README文件:

const MY_PLUGIN_NAME = “MyReadMePlugin”;

// 插件功能:自动生成README文件,标题取自插件option

class MyReadMePlugin {

constructor(option) {

this.option = option || {};

}

apply(compiler) {

compiler.hooks.emit.tapAsync(

MY_PLUGIN_NAME,

(compilation, asyncCallback) => {

compilation.assets[“README.md”] = {

// 文件内容

source: () => {

return # ${this.option.title || '默认标题'};

},

// 文件大小

size: () => 30,

};

asyncCallback();

}

);

}

}

// 7、模块导出

module.exports = MyReadMePlugin;

compiler.hooks 上挂载了不同时期触发的webpack事件函数(类似于React生命周期),可以在编译的各个阶段执行其他逻辑或者改变输出结果,具体支持的事件列表可以看这里:compiler-hooks

Tapable:

webpack 的插件架构主要基于 Tapable 实现的,Tapable 是 webpack 项目组的一个内部库,主要是抽象了一套插件机制。它类似于 NodeJS 的 EventEmitter 类,专注于自定义事件的触发和操作。

Tapable事件类型分为同步和异步,内部又以不同的规则分为不同类型,上述事件的具体区别可以看 这篇文章,理解这些事件的区别和应用场景有助于我们理解webpack源码和编写Plugin

Complier对象:

在webpack启动时被初始化一次,全局唯一,可以理解为webpack编译实例,它包含了webpack原始配置、Loader、Plugin引用、各种钩子

部分源码:https://github.com/webpack/webpack/blob/10282ea20648b465caec6448849f24fc34e1ba3e/lib/webpack.js

5. 性能优化


1. 从何开始?

  • 使用 speed-measure-webpack-plugin 测量打包速度

  • 使用 webpack-bundle-analyzer 进行体积分析

从某项目的分析图可以看出一个很明显的优化空间就是 BizCharts 没有按需引入,这时候我们可以import路径再执行一次打包分析看效果。

另外图中每个模块都有三种Size,分别是 Stat Size、Parsed Size、Gzipped Size,这三者的分别代表什么含义可以看下插件的github issue

2. 优化Loader配置

思路主要是优化搜索时间、缩小文件搜索范围、减少不必要的编译工作,具体做法可以看以下配置文件

module .exports = {

module : {

rules : [{

// 如果项目源码中只有 文件,就不要写成/\jsx?$/,以提升正则表达式的性能

test: /.js$/,

// babel-loader 支持缓存转换出的结果,通过 cacheDirectory 选项开启

use: [‘babel-loader?cacheDirectory’] ,

// 只对项目根目录下 src 目录中的文件采用 babel-loader

include: path.resolve(__dirname,‘src’),

// 使用resolve.alias把原导入路径映射成一个新的导入路径,减少耗时的递归解析操作

alias: {

‘react’: path.resolve( __dirname ,‘./node_modules/react/dist/react.min.js’),

},

// 让 Webpack 忽略对部分没采用模块化的文件的递归解析处理

noParse: ‘/jquery|lodash/’,

}],

}

}

3. DLL Plugin Or Externals

合理使用DLLPlugin将更改频率较低的代码(三方库)移到单独的编译中,我理解大部分场景下和配置 externals 作用是差不多的(都不用打包三方库),但是 externals 在某些场景下会存在失效问题,具体可以看 这篇文章,另外 DLLPlugin 具体使用 参考这里

4. 多进程系列

多进程阵营里有几位知名选手:

  • thread-loader(v4以后的官方推荐)

  • happypack(不怎么维护了)

  • parallel-webpack(不怎么维护了)

这里只介绍一下 thread-loader ,使用 thread-loader 将开销较大的 loader(例如babel-loader)放到独立进程中(官方描述 worker pool)处理,使用上有以下注意事项

  • 将其放在需要单独加载的loader的前面,顺序很关键

module.exports = {

module: {

rules: [

{

test: /.js$/,

include: path.resolve(“src”),

use: [

“thread-loader”,

// your expensive loader (e.g babel-loader)

]

}

]

}

}

  • worker pool中的loader使用上是有限制的,例如无法使用自定义 loader api,无法获取webpack 配置项

5. 合理利用缓存 缩短非首次构建时间

目前项目在用的插件是 hard-source-webpack-plugin,效果较为显著,不过缺点有3

  1. 生成的缓存文件较大,比较占用磁盘空间(之前还出现过发布的时候误把缓存文件上传到服务器导致发布特别慢的情况 =。=,所以最好还是指定缓存文件路径为 node_modules 内部)

  2. 这个仓库也很久没更新了

  3. 现有项目偶尔会出现更改代码不触发重新编译的情况,猜测可能与此插件有关

另外 webpack5 是否有自带的缓存策略或者官方维护的缓存插件还需要去了解一下

6. 代码压缩 减少产物体积

  • webpack3配置optimization.minimize = true会默认启用 UglifyJsPlugin,其多进程版本为 ParallelUglifyPlugin

  • webpack4 中 webpack.optimize.UglifyJsPlugin 已被废弃,默认内置使用 terser-webpack-plugin 插件压缩优化代码,原生支持多进程(这里想起官方文档 Build Performance 章节中列举的优化措施第一点:Stay Up to Date,最香的还是最新的webpack版本)

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注前端)
img

最后前端到底应该怎么学才好?

如果你打算靠自己摸索自学,那么你首先要了解学习前端的基本大纲,这是你将要学习的主要内容,理解以及掌握好这些内容,便可以找到一份初级的前端开发工作。你还需要有一套完整的前端学习教程,作为初学者最好的方式就是看视频教程学习,初学者容易理解接受。

不要选择买书学习,这样的方式没有几个人能学会,基本都是看不下去书,也看不懂书。如果喜欢看书的学弟,可以买一些经典的书籍作为辅助即可,主要还是以看教程为主。每天抽出固定几个小时学习,做好长期学习的准备。学习编程并不是每天光看视频,你学习编程最重要的目的是为了编写软件产品,提供给大众使用,所以用手写出代码实现功能才是我们要做的事情。

CodeChina开源项目:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

一个人可以走的很快,但一群人才能走的更远。如果你从事以下工作或对以下感兴趣,欢迎戳这里加入程序员的圈子,让我们一起学习成长!

AI人工智能、Android移动开发、AIGC大模型、C C#、Go语言、Java、Linux运维、云计算、MySQL、PMP、网络安全、Python爬虫、UE5、UI设计、Unity3D、Web前端开发、产品经理、车载开发、大数据、鸿蒙、计算机网络、嵌入式物联网、软件测试、数据结构与算法、音视频开发、Flutter、IOS开发、PHP开发、.NET、安卓逆向、云计算

1f54cfd94cf7b88a363ffa363f10.jpg?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3h6aXQ0OTQ4MDE4MzE=,size_16,color_FFFFFF,t_70#pic_center)

一个人可以走的很快,但一群人才能走的更远。如果你从事以下工作或对以下感兴趣,欢迎戳这里加入程序员的圈子,让我们一起学习成长!

AI人工智能、Android移动开发、AIGC大模型、C C#、Go语言、Java、Linux运维、云计算、MySQL、PMP、网络安全、Python爬虫、UE5、UI设计、Unity3D、Web前端开发、产品经理、车载开发、大数据、鸿蒙、计算机网络、嵌入式物联网、软件测试、数据结构与算法、音视频开发、Flutter、IOS开发、PHP开发、.NET、安卓逆向、云计算

  • 16
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值