Node.js 中的 module.exports 与 exports区别介绍
作者:Chrislinlin
这篇文章主要介绍了Node.js中的module.exports与exports区别介绍,每个模块中都有module对象,存放了当前模块相关的信息,更多相关内容需要的朋友可以参考一下
介绍
module
:每个模块中都有module
对象,存放了当前模块相关的信息;module.exports
:模块导出的内容;exports
:默认情况下,exports
和module.exports
指向同一个对象。
示例
test.js
console.log('module', module) console.log('module.exports', module.exports) console.log('exports', exports) console.log('module.exports === exports', module.exports === exports)
控制台执行 node test.js
,打印日志如下:
module Module { id: '.', path: 'E:\lin\webpack-learning\src\cjs\demo1', exports: {}, filename: 'E:\lin\webpack-learning\src\cjs\demo1\test.js', loaded: false, children: [], paths: [ 'E:\lin\webpack-learning\src\cjs\demo1\node_modules', 'E:\lin\webpack-learning\src\cjs\node_modules', 'E:\lin\webpack-learning\src\node_modules', 'E:\lin\webpack-learning\node_modules', 'E:\lin\node_modules', 'E:\node_modules' ] } module.exports {} exports {} module.exports === exports true
从源码中理解
const exports = this.exports; const thisValue = exports; const module = this;
说明:exports 是 module.exports 的引用
通过示例理解
示例一
test1.js
exports.name = 'lin'; module.exports.age = 18; console.log('module.exports', module.exports) console.log('exports', exports) console.log('module.exports === exports', module.exports === exports)
index.js
const test = require('./test1') console.log("test", test);
控制台执行 node index.js
,打印日志如下:
module.exports { name: 'lin', age: 18 } exports { name: 'lin', age: 18 } module.exports === exports true test { name: 'lin', age: 18 }
画图说明:
示例二
test2.js
module.exports.name = 'lin' exports = { name: 'myName', age: 6 } console.log('module.exports', module.exports) console.log('exports', exports) console.log('module.exports === exports', module.exports === exports)
index.js 改为引入 test2.js 模块
const test = require('./test2') console.log("test", test);
控制台执行 node index.js
,打印日志如下:
module.exports { name: 'lin' } exports { name: 'myName', age: 6 } module.exports === exports false test { name: 'lin' }
画图说明:
示例三
test3.js
module.exports = { name: 'lin', age: 18 } exports.name = "myName" console.log('module.exports', module.exports) console.log('exports', exports) console.log('module.exports === exports', module.exports === exports)
index.js 改为引入 test3.js 模块
const test = require('./test3') console.log("test", test);
控制台执行 node index.js
,打印日志如下:
module.exports { name: 'lin', age: 18 } exports { name: 'myName' } module.exports === exports false test { name: 'lin', age: 18 }
画图说明:
示例四
test4.js
exports = { name: 'lin', age: 18 } module.exports = exports module.exports.job = 'FE' console.log('module.exports', module.exports) console.log('exports', exports) console.log('module.exports === exports', module.exports === exports)
index.js 改为引入 test4.js 模块
const test = require('./test4') console.log("test", test);
控制台执行 node index.js
,打印日志如下:
module.exports { name: 'lin', age: 18, job: 'FE' } exports { name: 'lin', age: 18, job: 'FE' } module.exports === exports true test { name: 'lin', age: 18, job: 'FE' }
画图说明:
小结
exports
是module.exports
的引用;- 对
exports
和module.exports
赋值时要格外注意,明确模块导出的值; - 使用
require()
导入模块 A 时,导入的结果是模块 A 中module.exports
指向的值。
到此这篇关于Node.js 中的 module.exports 与 exports区别介绍的文章就介绍到这了,更多相关Node.js exports内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
您可能感兴趣的文章:
- CommonJS与ES6 Module的使用区别分析
- JavaScript ES6 Module模块详解
- node.js的exports、module.exports与ES6的export、export default深入详解
- ES6入门教程之Class和Module详解
- ES6中module模块化开发实例浅析
- ES6新特性之模块Module用法详解
- Node.JS中的模块、exports和module讲解
- Node.js中module.exports 和exports使用误区
- 详解Node.js中exports和module.exports的区别
- Node.js 中exports 和 module.exports 的区别
- node.js中module.exports与exports用法上的区别
- module.exports和exports使用误区案例分析