在 Webpack 5 中开启懒编译(Lazy Compilation)

sxkk20082年前知识分享221

在 webpack 5 中推出了 experiments 配置,目的是为了给用户赋能去开启并试用一些实验的特性。

由于实验特性具有相对 宽松的语义版本,可能会有重大的变更,所以你需要将 webpack 的版本固定为小版本号,例如与其使用 webpack: ~5.4.3 不如使用 webpack: ^5.4.3 或者当使用 experiments 配置时将版本锁定。

懒编译(Lazy Compilation)是什么

Lazy Compilation 是只有在用户访问时才编译,包含 2 点,使用入口点和动态导入的代码,它适用 Web 或 Node.js。

webpack 多入口配置

module.exports = {
  //...
  entry: {
    app: './app.js',
    home: './home.js',
    about: './about.js',
  },
}

将代码改成动态导入

// 之前
import { add } from './math'
console.log(add(16, 26))
// 之后
import('./math').then((math) => {
  console.log(math.add(16, 26))
})

React 项目可以使用 React.lazy 动态导入

// 之前
import OtherComponent from './OtherComponent'
// 之后
const OtherComponent = React.lazy(() => import('./OtherComponent'))
module.exports = {
  //...
+  experiments: {
+    lazyCompilation: true,
+  },
};

lazyCompilation 的可配置参数

  • boolean

开启为 true,包含入口和动态加载懒编译

  • object
{
// define a custom backend
backend?: ((
  compiler: Compiler,
  callback: (err?: Error, api?: BackendApi) => void
  ) => void)
  | ((compiler: Compiler) => Promise<BackendApi>)
  | {
    /**
     * A custom client.
    */
    client?: string;
    /**
     * Specify where to listen to from the server.
     */
    listen?: number | ListenOptions | ((server: typeof Server) => void);
    /**
     * Specify the protocol the client should use to connect to the server.
     */
    protocol?: "http" | "https";
    /**
     * Specify how to create the server handling the EventSource requests.
     */
    server?: ServerOptionsImport | ServerOptionsHttps | (() => typeof Server);
},
entries?: boolean,
imports?: boolean,
test?: string | RegExp | ((module: Module) => boolean)
}
  • backend:配置修改自定义后端,默认是 webpack dev-server
  • entries: 是否开启入口访问懒加载
  • imports 5.20.0+:是否开启动态导入的代码懒编译
  • test 5.20.0+: 指定哪些动态导入的模块需要懒编译

比如可以改成这样,将多入口改成懒编译,忽略动态导入的代码

module.exports = {
  // …
  experiments: {
    lazyCompilation: {
      imports: false,
      entries: true,
    },
  },
}

效果

我的项目有 10w+ 代码量,可以在 2s 内启动 启动效果

然后当再次输入 url 时,会再次编译,速度比 vite 了,不同的是 vite 是将 node_modules 预构建的。

输入url时再次编译

若在开启 webpack5 的文件缓存,将会非常快,当出入 url 时候就编译好看,几乎不需要等候编译

module.exports = {
  // …
  {
      type: 'filesystem',
      cacheDirectory: path.resolve('node_modules/.cache'),
      store: 'pack',
      ...
    }
};

小结

懒编译目前应该还在 beta,可能会有 BUG;next.js 其实就加过基于路由的懒编译,优点是能提速,缺点是跳转页面时需要等待,我认为懒编译在多页面项目必不可少,因为开发时候只是针对单个页面开发就够了。

以上就是本文全部内容,希望这篇文章对大家有所帮助,也可以参考我往期的文章或者在评论区交流你的想法和心得,欢迎一起探索前端。

本文首发掘金平台,来源Ai知识分享博客

相关文章

人工智能生活:新媒体创新之先导

人工智能生活:新媒体创新之先导

  随着人工智能技术的快速发展,我们的生活受益匪浅。从智能家居到智能穿戴,从语音助手到智能机器人,人工智能已经开始渗透到我们的方方面面。新媒体作为现代社会的重要组成部分,也受...

科技改变生活:体验智能家居带来的变革

科技改变生活:体验智能家居带来的变革

  在当今时代,科技已经成为我们生活中不可或缺的一部分。在家居领域中,智能家居的兴起大大改善了我们的生活质量,使得我们能够更加便利地享受生活。本文将着重介绍智能家居给我们带来...

语音识别SDK:打造智能语音交互的先驱技术

语音识别SDK:打造智能语音交互的先驱技术

  随着科技的飞速发展,语音识别技术的普及越来越广泛,人们对于语音交互的需求也日益增长。而在这一领域中,语音识别SDK作为关键技术之一,正扮演着不可或缺的角色。本文将围绕语音...

新的文档采用了全新的架构 next.js + Tailwind CSS ,改版后的文档界面有种焕然一新的感觉,支持暗黑模式,我们可以在线学习,并且写代码,采用了这种所见即所得的形式,大大降低了学习者的成本,我也被这种形式所深深吸引,那么这种所见即所得的形式是如何实现的呢?

基本介绍

新文档地址在 https://github.com/reactjs/reactjs.org/ 中的 beta 目录下,外层代码是目前的文档代码,那么我们可以直接 git clone 并且拷贝 beta 目录下的内容

这里面有 yarn.lock 文件,跟绝大多数 next 项目一样 yarn install 之后,运行 yarn dev 就可以运行开发环境

s16501401132022

启动速度非常快,仅仅 3.3s, 打开 http://localhost:3000,此时 next.js 会再次编译,大概 200ms,这种优势得益于 next.js 按需编译的优势,也就是是说当前启动的时候,并不会全站打包,而是当进入某个页面的时候编译当前页面,所以速度相当快。

约定式路由

s16384301132022 next 是约定式路由,在 pages 文件夹下的目录默认生成路由,即 '/src/pages/learn/add-react-to-a-website.md' 生成路由 /learn/add-react-to-a-website

此时发现里面的文档都是.md后缀的 Markdown 文件,那么 markdown 也可以写交互功能了吗? image.png

React 新的文档用到了哪些技术?

前言https://beta.reactjs.org React 的新的文档已经 完成了 70 % 并且呼吁社区进行翻译工作。 新的文档采用了全新的架构 next.js + Tailwind CSS...

AI机器人:未来的"智能生命"——人工智能技术的进一步发展

AI机器人:未来的"智能生命"——人工智能技术的进一步发展

  随着人工智能技术的不断发展和应用,AI机器人日益成为新时代的主角之一。作为未来的"智能生命",AI机器人不仅能够自主学习、自主思考,还可以执行各种任务,如生产制造、服务、...

阿里人脸识别:开创人工智能时代的身份验证进程

阿里人脸识别:开创人工智能时代的身份验证进程

  近年来,随着科技的不断进步和人工智能的快速发展,人脸识别作为一种快速、准确的身份验证技术,正逐渐渗透进我们的日常生活。作为国内的互联网巨头,阿里巴巴也不甘落后,旗下的阿里...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。