NodeJS 导入导出模块的方法( 代码演示 )
还是大剑师兰特:曾是美国某知名大学计算机专业研究生,现为航空航海领域高级前端工程师;CSDN知名博主,GIS领域优质创作者,深耕openlayers、leaflet、mapbox、cesium,canvas,webgl,echarts等技术开发,欢迎加底部微信(gis-dajianshi),一起交流。
No. | 内容链接 |
---|---|
1 | Openlayers 【入门教程】 - 【源代码+示例300+】 |
2 | Leaflet 【入门教程】 - 【源代码+图文示例 150+】 |
3 | Cesium 【入门教程】 - 【源代码+图文示例200+】 |
4 | MapboxGL【入门教程】 - 【源代码+图文示例150+】 |
5 | 前端就业宝典 【面试题+详细答案 1000+】 |
文章目录
- 一、 导出模块
- 1、导出单个值或函数
- 2、导出多个值或方法
- 二、 导入模块
- 1、导入单个
- 2、导入多个
- 三、Node.js 也支持 ES6 的默认导出语法
Node.js 中的模块系统是基于 CommonJS 规范的,它允许开发者通过 require 函数导入模块,通过 module.exports 或 exports 导出模块中的方法或变量。下面详细说明导入和导出的几种方式,并提供示例代码。
一、 导出模块
1、导出单个值或函数
在模块文件(例如 math.js)中,你可以导出一个单一的函数或值:
// math.js function add(a, b) { return a + b; } module.exports = add; // 将整个模块导出为add函数
2、导出多个值或方法
如果你需要导出多个值或方法,可以使用对象:
// utils.js const add = (a, b) => a + b; const subtract = (a, b) => a - b; module.exports = { add, subtract }; // 或者使用 exports 对象,但推荐使用 module.exports 方式以避免潜在问题 // exports.add = add; // exports.subtract = subtract;
二、 导入模块
1、导入单个
当你从模块中只导入一个导出时,可以直接赋给一个变量:
// app.js const add = require('./math'); console.log(add(2, 3)); // 输出 5
2、导入多个
如果模块导出了多个值或有一个默认导出,你可以这样导入:
// 假设 utils.js 如上述示例 const { add, subtract } = require('./utils'); // 解构赋值 console.log(add(5, 3)); // 输出 8 console.log(subtract(5, 3)); // 输出 2 // 如果模块有默认导出,可以这样使用 // const myDefaultExport = require('./defaultExportModule');
三、Node.js 也支持 ES6 的默认导出语法
Node.js 也支持 ES6 的默认导出语法,但需要注意的是,这种方式在 Node.js 中不如 CommonJS 方式常见,且需要使用 .mjs 文件扩展名或在 package.json 中配置 "type": "module" 来启用模块模式。
// defaultExport.js (需要使用 .mjs 扩展名或配置 package.json) export default function multiply(a, b) { return a * b; }
// 另一个文件中导入默认导出 import multiply from './defaultExport.mjs'; console.log(multiply(4, 5)); // 输出 20
总结来说,Node.js 的模块导入导出机制允许你组织和复用代码,通过清晰的接口提高代码的可维护性和模块化程度。
免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理!
部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理!
图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们,邮箱:ciyunidc@ciyunshuju.com。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!