Node.js--exports 对象详解:用法、示例与最佳实践

目录

[1. exports 对象介绍](#1. exports 对象介绍)

[2. 基础示例:使用 exports 导出对象](#2. 基础示例:使用 exports 导出对象)

文件名:math.js(JavaScript)

[3. 在另一个文件中使用 require 进行导入](#3. 在另一个文件中使用 require 进行导入)

文件名:app.js(JavaScript)

[4. 运行程序](#4. 运行程序)

[5. exports 的限制](#5. exports 的限制)

[6. 其他 exports 使用方式](#6. 其他 exports 使用方式)

示例1:导出单个函数

示例2:导出类

[7. 结论](#7. 结论)

1. exports 对象介绍

在 Node.js 中,exportsmodule.exports 的一个引用(别名),用于导出模块的内容。

主要特点:

  • exportsmodule.exports 最初指向同一个对象。
  • 只能使用 exports.属性 = 值 形式来添加属性,不能直接赋值 exports = {...},否则会断开与 module.exports 的关联。
  • 推荐使用 module.exports,因为它更清晰,避免 exports 赋值带来的问题。

2. 基础示例:使用 exports 导出对象

创建一个 math.js 文件,使用 exports 对象导出数学运算函数。

文件名:math.js(JavaScript)

javascript 复制代码
// math.js
exports.add = (a, b) => a + b;
exports.subtract = (a, b) => a - b;
exports.multiply = (a, b) => a * b;
exports.divide = (a, b) => (b !== 0 ? a / b : "Error: Division by zero");

3. 在另一个文件中使用 require 进行导入

创建 app.js 文件,并使用 require 来引入 math.js 模块。

文件名:app.js(JavaScript)

javascript 复制代码
// app.js
const math = require("./math"); // 引入 math.js 模块

console.log("加法 5 + 3 =", math.add(5, 3)); 
console.log("减法 10 - 4 =", math.subtract(10, 4)); 
console.log("乘法 6 * 7 =", math.multiply(6, 7)); 
console.log("除法 20 / 5 =", math.divide(20, 5)); 
console.log("除法 10 / 0 =", math.divide(10, 0)); // 测试除数为0的情况

4. 运行程序

在终端(Terminal 或 CMD)中运行:

bash 复制代码
node app.js

运行结果:

bash 复制代码
加法 5 + 3 = 8
减法 10 - 4 = 6
乘法 6 * 7 = 42
除法 20 / 5 = 4
除法 10 / 0 = Error: Division by zero

5. exports 的限制

错误示例(不建议使用):

javascript 复制代码
// math.js
exports = {  // ❌ 这样会导致导出失败
    add: (a, b) => a + b,
    subtract: (a, b) => a - b
};

原因: 这样做会让 exports 变量指向一个新对象,但 module.exports 仍然指向原始对象,导致 require('./math') 取不到新赋值的对象。


6. 其他 exports 使用方式

示例1:导出单个函数

文件名:greet.js(JavaScript)

javascript 复制代码
// greet.js
exports.greet = function(name) {
    return `Hello, ${name}!`;
};

文件名:app.js(JavaScript)

javascript 复制代码
// app.js
const greetModule = require("./greet");
console.log(greetModule.greet("鼠鼠"));

运行结果:

bash 复制代码
Hello, 鼠鼠!

示例2:导出类

文件名:Person.js(JavaScript)

javascript 复制代码
// Person.js
exports.Person = class {
    constructor(name, age) {
        this.name = name;
        this.age = age;
    }

    introduce() {
        return `My name is ${this.name}, I am ${this.age} years old.`;
    }
};

文件名:app.js(JavaScript)

javascript 复制代码
// app.js
const { Person } = require("./Person");

const person1 = new Person("Alice", 25);
console.log(person1.introduce());

const person2 = new Person("Bob", 30);
console.log(person2.introduce());

运行结果:

javascript 复制代码
My name is Alice, I am 25 years old.
My name is Bob, I am 30 years old.

7. 结论

  • exportsmodule.exports 的一个引用,默认指向相同的对象。
  • 只能使用 exports.属性 = 值 形式,不能直接 exports = {...} 赋值,否则会失去作用。
  • 一般推荐使用 module.exports,避免 exports 赋值带来的问题。
  • 适用于导出多个函数或对象时使用。

希望这篇文章能帮助你理解 exports 的用法!

相关推荐
万少15 小时前
HarmonyOS官方模板集成创新活动-流蓝卡片
前端·harmonyos
-To be number.wan17 小时前
C++ 赋值运算符重载:深拷贝 vs 浅拷贝的生死线!
前端·c++
噢,我明白了18 小时前
JavaScript 中处理时间格式的核心方式
前端·javascript
纸上的彩虹18 小时前
半年一百个页面,重构系统也重构了我对前端工作的理解
前端·程序员·架构
be or not to be19 小时前
深入理解 CSS 浮动布局(float)
前端·css
LYFlied19 小时前
【每日算法】LeetCode 1143. 最长公共子序列
前端·算法·leetcode·职场和发展·动态规划
老华带你飞19 小时前
农产品销售管理|基于java + vue农产品销售管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
小徐_233320 小时前
2025 前端开源三年,npm 发包卡我半天
前端·npm·github
C_心欲无痕20 小时前
vue3 - 类与样式的绑定
javascript·vue.js·vue3
GIS之路20 小时前
GIS 数据转换:使用 GDAL 将 Shp 转换为 GeoJSON 数据
前端