require导入module.exports 或 exports导出的使用

一、CommonJS 的导入和导出

1.定义

CommonJS 是一种用于 JavaScript 的模块化规范,用于在服务端环境和旧版浏览器中组织和管理代码。它定义了模块的导入(require)和导出(module.exports 或 exports)方式,并支持同步加载模块。

2.特点和使用方法

1.导入模块:
使用 require 函数来导入模块。
可以通过相对路径或绝对路径指定要导入的模块文件。
返回被导出的模块内容。

2.导出模块:
使用 module.exports 或 exports 对象导出模块内容。
可以导出变量、函数、对象或其他模块。
module.exports 是导出整个模块的内容,而 exports 是 module.exports 的一个引用。

3.同步加载:
require 函数是同步的,会阻塞后续代码的执行直到模块加载完毕。
适用于在服务器环境中加载本地模块或在旧版浏览器环境中加载模块。

4.动态加载:
可以在运行时根据需求动态加载模块。

5.块级作用域:
CommonJS 模块使用立即执行函数表达式(IIFE)封装,每个模块都具有自己的作用域。
模块内定义的变量和方法默认是私有的,不会暴露到全局作用域。

// 导出模块内容
module.exports = {
  variable1: value1,
  myFunction: function() { /* 函数体 */ }
};

// 导入模块
const myModule = require('./myModule');

// 使用导入的模块内容
console.log(myModule.variable1);
myModule.myFunction();

需要注意的是,在浏览器环境中,CommonJS 模块需要使用打包工具(如 Browserify、Webpack)将其转换为浏览器可识别的格式,或者使用库(如 RequireJS)来加载和管理模块。

三、具体使用

在 CommonJS 模块系统中,module.exports 和 exports 是指向同一个对象的引用,但不能直接将 exports 赋值为新对象或值,因为它只是 module.exports 的一个引用。如果想要导出一个新的对象或值,请使用 module.exports。

1.导出单个变量、函数或对象

module.exports = myVariable;
//或者
exports.myVariable = myVariable;

2.导出多个变量、函数或对象

module.exports = {
  variable1: value1,
  variable2: value2,
  myFunction: function() { /* 函数体 */ }
};

//或者
exports.variable1 = value1;
exports.variable2 = value2;
exports.myFunction = function() { /* 函数体 */ };

3.通过赋值给 exports 对象导出:

exports = {
  variable1: value1,
  variable2: value2
};

4.导入

//在 CommonJS 中,使用 require 导入模块时,会返回被导出的内容
const myModule = require('./myModule');

module.exports:用于导出整个模块的内容。可以通过赋值给 module.exports 导出一个对象、函数或值。导出的内容可以被其他模块通过 require 导入。例如:module.exports = myVariable;

exports:是 module.exports 的一个引用,并且可以通过添加属性和方法来导出多个值。当使用 exports.variable = value 导出时,实际上是在修改 module.exports 对象,将变量作为其属性添加进去。例如:exports.myFunction = function() { /* 函数体 */ };

需要注意的是,module.exports 和 exports 是同一份内存空间的引用,因此直接给 exports 赋予一个新的对象或值并不会更改 module.exports 的引用。所以,如果要导出一个新的对象或值,应该使用 module.exports。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值