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

 更新时间:2023年11月27日 14:55:46   作者:程序媛_MISS_zhang_0110  
module.exports用于导出整个模块的内容,可以通过赋值给 module.exports 导出一个对象、函数或值,导出的内容可以被其他模块通过require 导入,本文给大家介绍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 对象导出:

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

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。

到此这篇关于require导入module.exports 或 exports导出的使用的文章就介绍到这了,更多相关require导入module.exports内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • JavaScript读二进制文件并用ajax传输二进制流的方法

    JavaScript读二进制文件并用ajax传输二进制流的方法

    这篇文章主要介绍了JavaScript读二进制文件并用ajax传输二进制流的方法的相关资料,需要的朋友可以参考下
    2016-07-07
  • js实现window.open不被拦截的解决方法汇总

    js实现window.open不被拦截的解决方法汇总

    这篇文章主要介绍了js实现window.open不被拦截的解决方法,实例汇总了常用的不被拦截的解决方法,需要的朋友可以参考下
    2014-10-10
  • JavaScript JSON.stringify()的使用总结

    JavaScript JSON.stringify()的使用总结

    JSON是一种轻量级数据格式,可以方便地表示复杂数据结构。JSON对象有两个方法:stringify()和parse()。在简单的情况下,这两个方法分别可以将JavaScript序列化为JSON字符串,以及将JSON解析为原生JavaScript值。本文着重介绍JSON.stringify()的使用方法和注意事项。
    2021-05-05
  • JS前端分片上传大文件步骤(支持1G以上的超大文件)

    JS前端分片上传大文件步骤(支持1G以上的超大文件)

    当前端在开发过程中遇到上传文件需求,如果是小文件之类的可以正常按上传流程处理,但是当遇到上传大文件需求时就需要分片上传,这篇文章主要给大家介绍了关于JS前端分片上传大文件(支持1G以上的超大文件)的相关资料,需要的朋友可以参考下
    2024-08-08
  • JavaScript定义简单的页面复选框实现全选操作

    JavaScript定义简单的页面复选框实现全选操作

    本文主要介绍了JavaScript定义简单的页面复选框实现全选操作,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-05-05
  • JavaScript 12个有用的数组技巧

    JavaScript 12个有用的数组技巧

    数组是Javascript最常见的概念之一,它为我们提供了处理数据的许多可能性,熟悉数组的一些常用操作是很有必要的。本文将为大家介绍12个有用的JavaScript数组技巧,需要的朋友可以参考一下
    2021-12-12
  • JavaScript利用crypto模块实现加解密

    JavaScript利用crypto模块实现加解密

    crypto模块提供了加密功能,包含对 OpenSSL 的哈希、HMAC、加密、解密、签名、以及验证功能的一整套封装。本文将利用它实现加解密算法,需要的可以参考一下
    2023-02-02
  • 如何使用JS console.log()技巧提高工作效率

    如何使用JS console.log()技巧提高工作效率

    这篇文章主要介绍了如何使用JS console.log()技巧提高工作效率,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-10-10
  • JS中事件冒泡和事件捕获介绍

    JS中事件冒泡和事件捕获介绍

    这篇文章主要为大家详细介绍了JS中事件冒泡和事件捕获的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-12-12
  • javascript执行上下文详解

    javascript执行上下文详解

    执行上下文可以说是js代码执行的一个环境,存放了代码执行所需的变量,变量查找的作用域链规则以及this指向等。同时,它也是js很底层的东西,很多的问题如变量提升、作用域链和闭包等都可以在执行上下文中找到答案,所以这也是我们学习执行上下文的原因
    2023-05-05

最新评论