当前位置: 首页 > article >正文

一文大白话讲清楚webpack基本使用——11——chunkIds和runtimeChunk

文章目录

  • 一文大白话讲清楚webpack基本使用——11——chunkIds和runtimeChunk
  • 1. 建议按文章顺序从头看,一看到底,豁然开朗
  • 2. 啥是chunkIds
    • 3.怎么使用chunkIds
    • 4. 啥是runtimeChunk
    • 5. 怎么使用runtimeChunk

一文大白话讲清楚webpack基本使用——11——chunkIds和runtimeChunk

1. 建议按文章顺序从头看,一看到底,豁然开朗

  • 第一篇:
  • 一文大白话讲清楚啥是个webpack
  • 第二篇:
  • 一文大白话讲清楚webpack基本使用——1——完成webpack的初步构建
  • 第三篇
  • 一文大白话讲清楚webpack基本使用——2——css相关loader的配置和使用
  • 第四篇
  • 一文大白话讲清楚webpack基本使用——3——图像相关loader的配置和使用
  • 第五篇
  • 一文大白话讲清楚webpack基本使用——4——vue-loader的配置和使用
  • 第六篇
  • 一文大白话讲清楚webpack基本使用——5——babel的配置和使用
  • 第七篇
  • 一文大白话讲清楚webpack基本使用——6——热更新及其原理
  • 第八篇
  • 一文大白话讲清楚webpack基本使用——7——代码分离和懒加载
  • 第九篇
  • # 一文大白话讲清楚webpack基本使用——8——开发环境和生产环境的配置和区别
  • 第十篇
  • 一文大白话讲清楚webpack基本使用——9——预加载之prefetch和preload以及webpackChunkName的使用
  • 第十一篇
  • 一文大白话讲清楚webpack基本使用——10——使用CDN优化加载速度
  • 然后看本篇,chunkIds和runtimeChunk

2. 啥是chunkIds

  • chunkIds是optimization配置的一个属性项,用于告知webpack模块的id采用什么算法
  • 有三个常见的值
  1. named:development模式下默认值,属于一个可读的名称的ID
  2. natural:安装数字顺序使用ID。数字不是固定的,每次构建都会发生变化
  3. deterministic:确定性的,在不同的编译中不变的短数字ID,也就是说,无论你构建多少次,名字都是不变的,这么简单理解

** 在实际开发中,development模式下,我们使用named;production模式下我们使用deterministic **

3.怎么使用chunkIds

  • 在webpack.config.js中的optimization中配置就行
opptimization:{
    chunkIds:"named"
}

4. 啥是runtimeChunk

  • 配置runtime相关的代码,决定是否将runtime代码单独构建到一个包中去
  • 啥是runtime代码呢,就是在运行环境中,对模块进行解析、加载的代码
  • 还不理解,说具体点,我们上面第八篇文章,讲动态加载的时候,dynamic.js是在通过点击button之后加载来的,谁加再来的呢,就是runtime代码
  • 那为啥要把runtime代码单独构建成包呢
  • 还是涉及到代码分离提高加载速度的问题,如果分离了,及时主代码有变化,runtime代码也不用重新打包请求,不仅优化构建速度还利用缓存优化了加载速度

5. 怎么使用runtimeChunk

  • 在webpack.config.js中的optimization中配置就行
optimization:{
    runtimeChunk:'single'//single表示将运行时代码提取到一个单独的chunk中去
    //true/multiple,针对每个入口打包一个runtime文件
    //single,--
    //Object,name属性决定runtimeChunk的名称
}

在这里插入图片描述

  • 我们配置完以后重新构建一下
npm run build

-发现构建出了多一个包,就是runtimeChunk
在这里插入图片描述


http://www.kler.cn/a/515551.html

相关文章:

  • KNN的调参方法
  • Golang之Context详解
  • java 根据前端传回的png图片数组,后端加水印加密码生成pdf,返回给前端
  • NIO | 什么是Java中的NIO —— 结合业务场景理解 NIO (二)
  • Python的进程和线程
  • JS宏进阶:正则表达式的使用
  • 【玩转全栈】----基于ModelForm完成用户管理页面
  • 作品显示ip属地与定位哪个是真实的
  • 解决因JDK升级导致的`java.nio.file.NoSuchFileException`问题
  • 【K8S问题系列 |19 】如何解决 Pod 无法挂载 PVC问题
  • Python并发编程 07 事件驱动模型、进程切换、进程阻塞、文件描述符、缓存I/O、selectors模块
  • Vue3+Element Plus 实现 el-table 表格组件滚动是否触底监听判断
  • 父级perspective与子元素transform:perspective的区别
  • 在vue3中使用datav完整引入时卡在加载页面的解决方法
  • 【10.2】队列-设计循环队列
  • FFmpeg音视频采集
  • 数据结构——实验二·栈
  • 2025美赛倒计时,数学建模五类模型40+常用算法及算法手册汇总
  • 【2024年华为OD机试】 (E卷,100分) - 整数编码(JavaScriptJava PythonC/C++)
  • 4.C++中的循环语句
  • 【Mac】Python相关知识经验
  • 什么是网络爬虫?Python爬虫到底怎么学?
  • TDengine 与上海电气工业互联网平台完成兼容性认证
  • PySide6的简单介绍
  • elk 安装
  • 深度学习-91-大语言模型LLM之基于langchain的模型IO的提示模板