我的编程空间,编程开发者的网络收藏夹
学习永远不晚

webpackcjs运行时分析示例详解

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

webpackcjs运行时分析示例详解

准备工作(接上篇文章的示例也可以):

1. 在index.js文件中引入任一js文件

import sum from './sum';

const result = sum(1,2);
console.log(result);

2. sum文件

const sum = (a, b) => {
  return a+b;
}

export default sum

3. build.js文件

const path = require('path');
const webpack = require('webpack');

function wrapBuild() {
  return webpack({
    entry: './index.js',
    mode: 'none',
    output: {
      path: path.resolve(__dirname, 'build'),
      filename: '[name].js'
    },
    infrastructureLogging: {
      debug: true,
      level: 'log',
    }
  })
}

wrapBuild().run((err, stat) => {
  const startTime = stat.startTime;
  const endTime = stat.endTime;
  console.log('构建时间: ', endTime - startTime);
})

4. 命令行执行node ./build.js 生成打包产物main.js。

(截图未完整, 共87行)

5. 什么是运行时代码?

通过webpack打包得到的文件(如/build/main.js的骨架代码), 其中包含了一些webpack如何将多个模块集合在一起的代码, 可粗暴理解为webpack runtime 打包过后的代码。可通过node build/main.js可直接调试。

6. 示例打包js资源后的运行时代码分析:(含注解)

 (() => { // webpackBootstrap
 	"use strict";
 	var __webpack_modules__ = ([
,    // ---模块0, 入口模块 可以理解为index.js模块
    // ---模块1,打包过后的sum.js
 ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {

__webpack_require__.r(__webpack_exports__);
 __webpack_require__.d(__webpack_exports__, {
   "default": () => (__WEBPACK_DEFAULT_EXPORT__)
 });
const sum = (a, b) => {
  return a+b;
}

 const __WEBPACK_DEFAULT_EXPORT__ = (sum);

 })
 	]);

 	// 模块缓存
 	var __webpack_module_cache__ = {};
 	
 	// 模块加载器, 模拟实现common.js的require
 	function __webpack_require__(moduleId) {
 		// 根据moduleId从缓存中读取module
 		var cachedModule = __webpack_module_cache__[moduleId];
            // 若缓存中存在该模块,则返回当前的module.exports
 		if (cachedModule !== undefined) {
 			return cachedModule.exports;
 		}
 		// 缓存中不存在该模块,则去__webpack_modules__里取。
                // 创建一个新的模块,  写入cache对象, key为moduleId, value 为 exports对象
 		var module = __webpack_module_cache__[moduleId] = {
 			// no module.id needed
 			// no module.loaded needed
 			exports: {}
 		};
 	
 		// 调用包裹函数,计算模块信息,解析出相关模块内容(如:exports)
 		__webpack_modules__[moduleId](module, module.exports, __webpack_require__);
 	
 		// 返回当前解析过后的module.exports
 		return module.exports;
 	}

var __webpack_exports__ = {};
// 加载入口函数
(() => {
__webpack_require__.r(__webpack_exports__);
 var _sum__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1);
const result = (0,_sum__WEBPACK_IMPORTED_MODULE_0__["default"])(1,2);
console.log(result);
})();

 })()
;

该运行时代码一共做了三件事:

  • __webpack_modules__ : 维护一个所有模块的数组,通过深度优先遍历将其全部转换为AST,以供给后面的包裹函数解析
  • __webpack_require__: 手动实现一个模块加载器;优先从缓存列表__webpack_module_cache__中读取模块,并返回其exports内容。如果缓存中没有,则调用包裹函数解析出模块exports等重要内容,存入缓存列表中并返回exports。
  • 调用__webpack_require_(0): 运行入口模块.

7. 疑问?

  • 如果不对模块进行缓存,会有什么问题?
  • 模块内容重复计算,消耗性能。
  • 每个模块只在第一次引用的时候产生一个对象,后面都是引用该对象,减少代码复杂度。
  • module.exports和exports有什么区别?
  • 默认情况下,Node准备的exports变量和module.exports变量实际上是同一个变量,并且初始化为空对象,我们可以把要输出的东西直接加入在这个空对象里面;但是,如果我们要输出的是一个函数或数组,那么,只能给module.exports赋值,给exports赋值是无效的,因为赋值后,module.exports仍然是空对象。
  • 结论:
  • 如果要输出一个键值对象{},可以利用exports这个已存在的空对象{},并继续在上面添加新的键值;
  • 如果要输出一个函数或数组,必须直接对module.exports对象赋值。
  • 建议直接对module.exports赋值,可以应对任何情况;

参考文献

详细的可移步大佬的文章

到此这篇关于webpack cjs运行时分析的文章就介绍到这了,更多相关webpack cjs运行时内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

webpackcjs运行时分析示例详解

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

webpackcjs运行时分析示例详解

这篇文章主要介绍了webpackcjs运行时分析,本文结合示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
2022-12-28

JavaScript运行的示例分析

这篇文章给大家分享的是有关JavaScript运行的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1.1 语法分析预编译之前,先通篇扫描看看有没有语法错误1.2 预编译 1.2.1 函数声明整体提升声明函
2023-06-29

Java线程运行的示例分析

这篇文章将为大家详细讲解有关Java线程运行的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。栈与栈帧JVM中由堆、栈、方法区所组成,其中栈内存就是分配给线程使用的,每个线程启动后,虚拟机都会为其分
2023-06-29

java中JVM运行时内存整理的示例分析

这篇文章给大家分享的是有关java中JVM运行时内存整理的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Java可以用来干什么Java主要应用于:1. web开发;2. Android开发;3. 客户端开
2023-06-14

SparkSQl中运行原理的示例分析

这篇文章将为大家详细讲解有关SparkSQl中运行原理的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一:什么是SparkSQL?(一)SparkSQL简介Spark SQL是Spark的一个模块
2023-06-20

centos破解密码及运行级别的示例分析

小编给大家分享一下centos破解密码及运行级别的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1.什么都不教,教你先看系统版本(依稀记得第一次帮客户看版
2023-06-10

Flink on yarn运行原理的示例分析

小编给大家分享一下Flink on yarn运行原理的示例分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!Flink运行时由两种类型的进程组成:1),JobManager也叫master协调分布式执行。他们调度任务,协调
2023-06-19

kubernetes中kubelet运行机制的示例分析

这篇文章给大家分享的是有关kubernetes中kubelet运行机制的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。一:简介在Kubernetes集群中,每个Node节点上都会启动一个Kubelet服务
2023-06-04

C++实现统计代码运行时间的示例详解

这篇文章主要为大家详细介绍了C++一个有趣的小项目——统计代码运行时间,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
2023-05-19

PHP中CLI命令行运行模式的示例分析

这篇文章将为大家详细讲解有关PHP中CLI命令行运行模式的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。PHP的CLI命令行运行模式浅析在做开发的时候,我们不仅仅只是做各种网站或者接口,也经常需要
2023-06-15

Python运行是由Graminit.c定义的示例分析

本篇文章为大家展示了Python运行是由Graminit.c定义的示例分析,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。Graminit.c中定义了Python运行时刻进行语法分析所需要的静态数据(
2023-06-17

Golang中运行与Plan9汇编的示例分析

小编给大家分享一下Golang中运行与Plan9汇编的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!Golang的运行环境当我们把编译后的Go代码运行起来
2023-06-16

springboot项目以jar包运行的示例分析

这篇文章将为大家详细讲解有关springboot项目以jar包运行的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、pom文件配置  1、打包方式改成jarjar
2023-06-20

Tomcat运行Java Web内存溢出的示例分析

这篇文章主要介绍Tomcat运行Java Web内存溢出的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!如果JVM里运行的程序, 它的内存堆和持久存储区域的都满了,这个时候程序还想创建对象实例的话,垃圾收集器
2023-06-17

PHP中CI框架运行模式的示例分析

小编给大家分享一下PHP中CI框架运行模式的示例分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!php有什么用php是一个嵌套的缩写名称,是英文超级文本预处理语言,它的语法混合了C、Java、Perl以及php自创新的语
2023-06-14

CentOS7.1中开机运行模式run level的示例分析

这篇文章主要介绍CentOS7.1中开机运行模式run level的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!在大多数的linux发行版本中,通常有8个 runlevelRunlevel System S
2023-06-10

linux中shell脚本编写和运行的示例分析

这篇文章主要介绍了linux中shell脚本编写和运行的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。编写第一个shell脚本在gedit中编写.sh格式的文件,保存
2023-06-09

编程热搜

目录