前端面试题整理-webpack

news2025/1/11 18:04:27

在这里插入图片描述
实现前端模块化,将多个 js,打包成一个 bundle.js (其他类型文件交由各自的 loader 处理)

1. webpack 了解吗?大概介绍一下

一种打包工具,实现前端模块化,将多个 js,打包成一个 bundle.js (其他类型文件交由各自的 loader 处理)。
其中核心概念:
entry: 定义入口 js 文件,一般单页项目定义一个,多页项目可传递数组
output: 定义输出文件的格式和目录
module: loader 定义的地方,常见的 jsx 处理用 babel-loader, vue 用 vue-loader, less 用 less-loader.(css 相对特殊,需要三个 loader 分别进行处理。各司其职,功能最小化)
plugin:
html-webpack-plugin, 在 html 文件中自动引入 js 文件
clean-webpack-plugin,在下次构建前清理上一次的打包产物

以 entry 作为入口,对代码静态分析 import 了哪些文件,通过不同的 loader 对不同后缀的文件处理,最终打包到一起。在最后的打包过程中,插件可以在适当的时机进行额外的操作。

2. loader 了解吗?常见的 loader 有哪些?

loader是从后往前执行,谁先定义后执行。
loader 本质是在 webpack 处理文件前,进行一次转换,可以是对新js语法的兼容(babel),也可以是对 css 文件的处理(css-loader, style-loader)
webpack 本身只能处理 js 文件,所以需要各种 loader 来对其他类型的文件进行处理。也正是因为 loader 机制的设定,webpack 的能力也非常便于扩展。

常见loader:
babel-loader: 实现对 es6 语法向 es5 的兼容
less-loader: 实现 .less 文件向 .css 文件的转换
css-loader: 处理 css 文件中,url, @import 这样的语法,转换成 js 可以处理的形式
style-loader: 将 css 文件,改成生成 style 标签并插入 html 中的功能
在这里插入图片描述
在这里插入图片描述

3. plugin 了解吗?常见的 plugin 有哪些?

plugin是对webpack现有功能的扩展,可以用于打包优化、文件压缩等多种目的。
常见plugin:
mini-css-extract-plugin:将项目中引入的 css 文件合并提取到一个 css 文件中,将 css 单独独立出来,可以更好的和 js 文件并行加载,提升页面性能。实际配置中,可以在开发环境使用 style-loader, 加快编译速度,而生产环境中使用 mini-css-extract-plugin,提高页面加载速度
html-webpack-plugin: 将打包出来的 js 文件,自动插入指定的 html 模版中,并生成 html 文件。可以多次使用,从而打包多个页面。
clean-webpack-plugin: 可以在打包前,清除上一次打包的产物
copy-webpack-plugin: 可以将指定目录下的文件直接复制到指定路径。一般用于处理静态资源的移动,比如图片,视频等
DefinePlugin: 可以配置全局对象,在页面 js 执行时可以直接获取。也就是在编译时,将变量注入运行时的环境。

4. loader 和 plugin 有什么区别?

plugin 具有比 loader 更大的能力:能够在 webpack 的整个编译过程中介入。
而 loader 只有处理单个文件时,会被使用。
比如 style-loader,一个 css 文件,就会插入一个 style 标签,而我们想要的 css 往往是合并成一个 .css 文件,而不是以 style 标签的形式插入。
style-loader 由于每次只能处理一个文件,所以并不具备把所有 css 文件合并的能力。
plugin 就是为了弥补这些不足而出现的,它的能力范围更大。

5. webpack 打包比较慢,为什么?有什么优化方法吗?

(1)webpack为什么打包慢?
webpack 的工作,会根据 entry 中指定的 js,一个一个加载并调用 loader 进行处理后,最终生成一个 bundle 文件。
打包慢,大概率就在于要处理的文件太多。不过现在 webpack 在文件修改后,本身就有优化,所以打包慢,一般发生在冷启动,和生产环境打包时。
(2)优化方法?
在这里插入图片描述

调整 loader 配置,增加 exclude,不对 node_modules 中文件进行处理,通过减少要处理的文件来减少构建时间;
在这里插入图片描述

增加 cache-loader,缓存之前的结果;
在这里插入图片描述

使用 Terser 开启多进程;
在这里插入图片描述
拆分项目,采用微前端的方案进行加载(把一个项目的多个页面进行拆分,通过微前端的技术将一个一个项目合并起来)。

6. webpack 有什么方法,可以使打包出来的页面性能更好?

(1)js, css 文件压缩,减少文件体积
(2)js, css 打包文件名增加 hash 值(output 中 filename 使用 [hash] 即可插入文件 hash 值),借助 http 强缓存减少加载耗时
(3)图片压缩,借助 image-webpack-loader 或者手动压缩图片后引入,减少页面资源体积
(4)tree-shaking:webpack 中开启 usedExports: true。引入的 npm 包如果支持,也会自动 shaking,无需配置
(5) 通过懒加载拆分不同路由的文件,按需加载 js
懒加载:不是在最顶部放入import,会返回一个promise。当文件被加载完成后,才会执行它的.then
在这里插入图片描述

7. tree-shaking 是什么?如何开启?

原理:静态代码分析
对于不是ES6语法定义的npm包可以坐tree-shaking吗?不能,开启 tree-shaking 的条件是使用 import 和 export。
本质:对代码静态分析,从入口文件开始,递归分析所有文件和他们的依赖关系。这一分析可以确定,哪些模块和模块的导出是被实际使用的。标记未使用的代码,即可在打包阶段进行移除。
webpack 中,通过配置 usedExports = true 开启 tree-shaking。
对于 npm 包中的内容,会通过 package.json 中的 sideEffects 来判断是否对其进行 tree-shaking
如果 sideEffects 为 false, 则认为该 npm 包没有副作用(修改了全局变量,执行某些初始化逻辑等),会正常进行 tree-shaking,否则不做处理。
该参数也可以指定为数组,从而对那些文件不进行 tree-shaking。
要注意,开启 tree-shaking 的条件是使用 import 和 export。如果是一些旧的 commonjs 等,是不支持 tree-shaking 的。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2068880.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Linux中查看端口被哪个进程占用、进程调用的配置文件、目录,address already in use端口被占用杀死并释放端口

1.查看被占用的端口的进程(netstat和ss是一样的,较新的系统推荐ss): netstat -antulp | grep 端口号ss -antulp | grep :端口号lsof -i | grep 端口号2. 通过上面的命令就可以列出,这个端口被哪些应用程序所占用,然后找…

Java设计模式之策略模式详细讲解和案例示范

Java设计模式之策略模式详细讲解和案例示范 在软件开发中,策略模式是一种常见且非常有用的设计模式。它允许定义一系列算法,将它们一个个封装起来,并且使它们可以互相替换。策略模式让算法可以独立于使用它们的客户端而变化。本篇文章将详细…

VScode的python虚拟环境

1 创建虚拟环境(venv) 在VSCode中打开项目文件夹,键盘按住快捷键ctrl shift p,打开命令面板,输入python:创建环境 选择venv,输入解释器路径,此时左侧文件夹内会出现一个.venv文件夹 2 激活虚拟…

未来已来:探索机器学习如何重塑人工智能的未来方向

引言:机器学习室实现人工智能的关键技术手段,应用领域持续延伸 机器学习是人工智能的一个重要分支,主要研究如何让计算机系统通过数据学习并做出决策或预测,而不需要明确的编程。简单来说,就是让计算机利用经验来提高性…

C# 如何实现接口事件:详解与示例

文章目录 实现接口事件的步骤示例:实现接口事件1. 定义接口事件2. 实现接口事件3. 订阅和触发事件4. 使用示例 总结 在C#中,接口(interface)是一种定义类必须实现的方法和属性的抽象类型。除了方法和属性,接口还可以包…

浅谈红队攻防之道-CobaltStrike钓鱼攻击集锦

打个比方,一片大地上,躺着一群沉睡的人,远处就是火山,马上就要爆发了,你就像个闹钟,面对这些沉睡的人,你想把他们叫醒。 你持续不断地响着,有的睡得浅的人,被你叫醒了&am…

区块链基础通识(1)——分布式系统的共识问题

分布式系统 我们最初了解区块链的时候,很多人会形容这个区块链是一个“分布式的不可篡改账本”,这是一个很形象的说法,但是我认为更为准确的形容是“所有节点共同维护的状态机”。为什么分布式和区块链不能划等号呢? 两种常见的…

Ubuntu 22.04中解决Could not load the Qt platform plugin “xcb“问题解决方法

摘要:在Ubuntu 22.04中安装OpenCV后,遇到“load the Qt platform plugin “xcb” in site-packages/cv2/qt/plugins" even though it was found. 的问题,导致程序无法启动。本文详细探讨了该问题的成因,并介绍了几种常见但无…

在线英语学习小程序App源码开发技术探讨

引言 随着信息技术的飞速发展和全球化进程的加快,英语学习已经成为越来越多人的日常需求。传统的纸质材料和课堂教学已经无法满足现代人灵活、高效的学习需求。因此,开发一款在线英语学习小程序App成为了一个热门话题。本文将从技术角度探讨在线英语学习…

SX_gitlab图形化案例_19

由图形去理解gitlab反而更直观: 圆圈代表着本机代码所在的位置 这就代表着,本机的代码和远程仓库,jhy_gnss的代码是一样的 一个原点代表着一次改动 merge branch ‘jhy_gnss’ of 192.168.91.10:t3000 into jhy_gnss 这条命令是将GitLab服…

Frog4Shell — FritzFrog 僵尸网络将一日攻击纳入其武器库

FritzFrog 的背景 Akamai 通过我们的全球传感器网络持续监控威胁,包括我们之前发现的威胁。其中包括FritzFrog 僵尸网络(最初于 2020 年发现),这是一个基于 Golang 的复杂点对点僵尸网络,经过编译可同时支持基于 AMD 和 ARM 的机器。该恶意软件得到积极维护,多年来通过增…

基于FPGA的ASIC prototype验证

在当今快速发展的电子设计自动化(EDA)领域,专用集成电路(ASIC)的开发因其高性能、低功耗和定制化的特点而备受青睐。然而,ASIC的设计和制造过程不仅成本高昂,而且周期漫长,一旦进入生…

数学建模之数据分析【八】:数据预处理之数据格式化

文章目录 一、在Pandas中格式化数据框的浮点列1.1 将列值四舍五入到两位小数1.2 使用逗号和小数精度的 Pandas DataFrame 格式1.3 在 Pandas DataFrame 中格式化和缩放人口数据 二、如何检查Pandas DataFrame 中的数据类型2.1 创建 DataFrame 检查 DataType2.1.1 创建数据集2.1…

《前端攻城狮 · Vue 使用腾讯地图》

📢 大家好,我是 【战神刘玉栋】,有10多年的研发经验,致力于前后端技术栈的知识沉淀和传播。 💗 🌻 CSDN入驻不久,希望大家多多支持,后续会继续提升文章质量,绝不滥竽充数…

React18快速入门教程

项目流程 开发流程 技术选型 创建项目 执行命令: pnpm create vite项目配置 editorconfig:用于配置编辑器,实现使用不同的编辑器打开效果是相同的包配置:主要用于配置国内源eslint配置:主要用于配置语法规则prettier&…

leetCode - - - 二分查找

目录 1.二分查找(Leetcode 704) 2.搜索插入位置( LeetCode 35 ) 3.寻找峰值(LeetCode 162) 4.旋转数组的最小数字(BM21) 5.总结 1.二分查找(Leetcode 704&#xff0…

基于Python的机器学习系列(7):多元逻辑回归

在本篇博文中,我们将探讨多元逻辑回归,它是一种扩展的逻辑回归方法,适用于分类数量超过两个的场景。与二元逻辑回归不同,多元逻辑回归使用Softmax函数将多个类别的概率输出映射到[0, 1]范围内,并确保所有类别的概率和为…

利用漏洞实现 Outlook 的 RCE:第一部分

概述 2023 年 3月补丁星期二解决的漏洞中,有一个是Outlook 的一个严重漏洞,编号为CVE-2023-23397,该漏洞被 Forest Blizzard 在野利用,微软已将其确定为俄罗斯国家支持的威胁行为者。2023 年 12 月,微软与波兰网络司令部 (DKWOC) 联合发布消息称,他们发现同一威胁行为者…

Debug-023-Document.createElement()的使用

Document.createElement() document.createElement()是在对象中创建一个对象,要与appendChild() 或 insertBefore()方法联合使用。 appendChild() 方法在节点的子节点列表末添加新的子节点。 insertBefore() 方法在节点的子节点列表任意位置插入新的节点。 用途举…

Linux -- git

1 啥是git git是一个代码的历史版本管理工具,通过用树形结构管理一个代码版本可以快速实现回滚等操作 1.1 git基本概念 工作区(Working Directory/Working Tree): 这是你当前正在处理项目文件的地方。你可以在工作区中创建、修改…