深入探究exports等是否为全局变量
变量有哪些
- exports
- require
- module
- __dirname(学过webpack的朋友看到这个肯定不会陌生)
- __filename
这里我们打印看看都是什么
console.log(exports);
console.log(require);
console.log(module);
console.log(__dirname);
console.log(__filename);
看看打印结果
这里就是上述五个值打印的结果
大胆假设
这里,我们先做一个大胆假设来证明exports是不是全局变量
假设为:我们运行的代码都是在一个函数当中,exports等看似为全局变量的变量实际为函数的参数。
console.log(arguments);
我们来看看打印结果
是不是感觉和上面的打印结果一致
如果你还不详细,我们还可以做一个验证
console.log(arguments[0] == exports);
console.log(arguments[1] == require);
console.log(arguments[2] == module);
console.log(arguments[3] == __filename);
console.log(arguments[4] == __dirname);
这下可以证明了吧
综上所述:我们的代码都是放在node的函数当中。
module模块探究
这里打印了一下module,
- id : 模块id
- exports : 导出的对象
- parent: 是否导出到其他模块中
- filename: 文件的详细名称
- loaded:该模块是否已经加载完毕(解析到打印这一行的时候,该模块还在执行,所以为false)
- paths: 当我们require了一个模块,他就会从paths里从上往下找