webpack打包流程

打包流程

  1. 初始化
  • 读取config配置
  • 创建compiler实例
  • 加载插件
  1. 编译阶段 从入口文件递归解析依赖关系分析,生成依赖图
  2. 模块处理 通过loader转译,比如balel,sass-loader处理等。
  3. 输出chunk 将各个依赖文件生成对应的chunk代码块,此时会走插件逻辑。
  4. 生成文件 根据输出配置filename、path等生成最终的bundle

常用的面试题

Webpack 的 Loader 和 Plugin 有什么区别

  • loader: loader的功能是将特定的文件转译成浏览器能识别的js文件。如 babel-loaderfile-loader
  • Plugin: 插件,属于是拓展的功能,可以在webpack各个打包流程的生命周期函数中做特殊处理。 如HtmlWebpackPluginMiniCssExtractPlugin

如何优化 Webpack 构建速度?

优化方案:

  • 编译阶段
    • 缓存 cache: { type: 'filesystem' }
    • 优化loader作用范围 :比如使用exclude,精确loader作用范围,以提高效率。
  • 开发阶段
    • 代码分割 treehShaking 等
    • 开启多线程等:happyPack
  • 压缩代码体积
    • 比如图片给一个maxSize
js 复制代码
{
        test: /\.(jpe?g|png|svg|gif)$/i,
        type: "asset",
        parser: {
          dataUrlCondition: {
            maxSize: 25 * 1024, // 25kb
          },
        },
        generator: {
          filename: "assets/imgs/[name].[hash:8][ext]",
        },
      },

什么是 Tree Shaking?如何生效?

package.json 配置 sideEffects:false;会将没有使用的代码去掉 treeshaking的限制:只支持esm语法。

js 复制代码
// 原始代码(问题:全量引入lodash)
import _ from 'lodash';
export const deepClone = (obj) => _.cloneDeep(obj);

// 优化后(按需引入 + 纯函数标记)
import { cloneDeep } from 'lodash-es';
export const deepClone = /*#__PURE__*/ (obj) => cloneDeep(obj);

如何实现按需加载(懒加载)?

使用动态导入的方法

相关推荐
snow@li7 天前
前端:构建工具(Vite / Webpack)的 文件指纹(File Hash) 机制 / 浏览器缓存控制
前端·webpack·哈希算法
SwJieJie10 天前
Webpack vs Vite 构建工程化实战(Vue 项目深度解析)
前端·vue.js·webpack·node.js
2401_8856651912 天前
基于OpenCV的银行智能卡号识别系统完整实现与原理剖析
人工智能·opencv·webpack
xiaofeichaichai13 天前
Webpack
前端·webpack·node.js
代钦塔拉13 天前
VS+OpenCV诡异LNK2019终极解决方案
webpack
半岛@少年16 天前
Webpack在前端项目中究竟发挥什么作用?
前端·webpack·前端工程化
咸鱼翻身小阿橙16 天前
高斯模糊降噪/磨皮算法降噪图像
前端·opencv·算法·webpack·c#
kyriewen17 天前
从Webpack到Vite:我们迁移了一个10万行代码的项目,总结了这7个坑
前端·webpack·vite
漂流瓶jz20 天前
Webpack如何实现万物皆可import?loader的使用/配置/手写实践
前端·javascript·webpack