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 的用法!

相关推荐
Dontla23 分钟前
黑马node.js教程(nodejs教程)——AJAX-Day01-04.案例_地区查询——查询某个省某个城市所有地区(代码示例)
前端·ajax·node.js
威哥爱编程24 分钟前
vue2和vue3的响应式原理有何不同?
前端·vue.js
呆呆的猫28 分钟前
【前端】Vue3 + AntdVue + Ts + Vite4 + pnpm + Pinia 实战
前端
qq_4560016530 分钟前
30、Vuex 为啥可以进行缓存处理
前端
浪裡遊1 小时前
Nginx快速上手
运维·前端·后端·nginx
天生我材必有用_吴用1 小时前
Vue3后台管理项目封装一个功能完善的图标icon选择器Vue组件动态加载icon文件下的svg图标文件
前端
小p1 小时前
初探typescript装饰器在一些场景中的应用
前端·typescript·nestjs
晓得迷路了1 小时前
栗子前端技术周刊第 72 期 - 快 10 倍的 TypeScript、React Router 7.3、Astro 5.5...
前端·javascript·typescript
xiaoyan20151 小时前
vue3仿Deepseek/ChatGPT流式聊天AI界面,对接deepseek/OpenAI API
前端·vue.js·deepseek
加个鸡腿儿1 小时前
D老师:如何正确控制图片尺寸?父容器设置为何失效?
前端·css