在使用 webpack 对脚本进行打包, 在开发中, 每一个文件中都会使用 import 语句来导入一些功能,又会使用 export 语句导出一些功能,为了研究 import 和 export 原理,研究了 webpack 打包后的代码,其实原理也是很是简单:webpack
webpack 对全部输入文件都打包到一个文件中:web
在最终的输出文件中,webpack 会定义一个 Object 对象,这个对象中放入了全部的输入文件的内容, 以文件名为 key, 文件内容(字符串)做为值,如:函数
var modules= {};ui
modules['index'] = "源代码";对象
modules['hello'] = '源代码';开发
固然,webpack 会对源代码进行必定的修改, 会把 export 语句修改成 exports.变量 = 值, 这种方法, exports 是一个参数, 大概是这样子的:字符串
modules['index'] = (function(exports) {io
// 代码,放在一个私有域中。console
// 经过 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 对象
}