webpack 里的 import, exports 实现原理

在使用 webpack 对脚本进行打包, 在开发中, 每个文件中都会使用 import 语句来导入一些功能,又会使用 export 语句导出一些功能,为了研究 import 和 export 原理,研究了 webpack 打包后的代码,其实原理也是非常简单:

webpack 对所有输入文件都打包到一个文件中:

在最终的输出文件中,webpack 会定义一个 Object 对象,这个对象中放入了所有的输入文件的内容, 以文件名为 key, 文件内容(字符串)作为值,如:

var modules= {};

modules['index'] = "源代码";

modules['hello'] = '源代码';

 

当然,webpack 会对源代码进行一定的修改, 会把 export 语句修改为 exports.变量 = 值, 这种方法, exports 是一个参数, 大概是这样子的:

 

modules['index'] = (function(exports) {

  // 代码,放在一个私有域中。

  // 通过 exports 对象,把需要公开的变量,函数,类公开出去。

  exports.xx = xxx;

});

这就大概是一个源文件最终的结果,变成了一个函数,那么这个 exports 到底是个什么对象?其实 exports 就是一个 Object 对象,里面没有任何其实内容,全部是函数中设置的内容,作用只是把对象传递到 import 语句:

先来看看 import 的语法: import xxx from 'filename'

import 语句, 最终大概会变成这样:

var cmp1 = require('filename');

require 函数大概的实现:

function require(id) {

if(installedModules[id]) {

  return installedModules[id].exports; // 返回 exports 对象

}

var module = installedModules[id] = {
      i: moduleId,
      l: false,
      exports: {} // 定义 exports 对象
 };
 
modules[id](module.exports); // 把 exports 参数传递到函数中
return module.exports; // 最后返回
}
 
不管 import xxx 语句中的 xxx 怎么设置, 最终都会变成一个变量,引用模块的 exports 对象,然后通过这个变量来访问变量,函数等:
import { a, b } from 'filename'
 
console.log(a);
console.log(b);
 
最终编译的结果:
var cmp1 = require('filename');
console.log(cmp1.a);
console.log(cmp1.b);
 
最后, 文件传统执行入口文件的代码 require('index');

转载于:https://www.cnblogs.com/kuku/p/11247316.html

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值