在 ES6 中使用 module.exports 导出多个函数

Posted

技术标签:

【中文标题】在 ES6 中使用 module.exports 导出多个函数【英文标题】:Exporting multiple functions with module.exports in ES6 【发布时间】:2021-08-05 08:03:45 【问题描述】:

我正在构建一个 node.js 应用程序,并试图将我所有的 mongodb 逻辑放在一个单独的文件中。此时这个文件只有一个初始化mongodb连接的功能。我想使用module.exports从这个文件中导出所有函数。

我的 mongo 文件如下所示:

import  connect  from "mongoose";

const run = async (db: string): Promise<void> => 
  await connect(db, 
    useNewUrlParser: true,
    useUnifiedTopology: true,
  );
;

module.exports = 
  run
;

我想在 index.ts 中使用这个 run 函数,我试图将它作为一个 ES6 模块导入,但我无法让它与上面的代码一起工作。

我是如何导入的:

index.ts:

import * as mongo from "./mongo";

尝试调用我的运行方法:

mongo.run('dburl');

这会引发以下错误:'property run does not exist'

现在我找到了解决这个问题的方法,方法是在我的运行声明之前添加一个额外的导出:

export const run = async (db: string): Promise<void> => ...

我不明白为什么我必须这样做,因为我已经在module.exports 中导出了这个函数,是我在索引文件中导入错误还是有更好的方法?

【问题讨论】:

尝试使用import mongo from "./mongo"; module.exports 是 common.js,不是 ES6,你可以这样做 export run 【参考方案1】:

MDN: javascript Modules

JS中有不同类型的模块。

ES6 模块使用export 关键字。您可以像import * as ... from "..." 这样导入所有导出,也可以通过import ... from "..." 导入单个导出

CommonJS 模块使用modules.exports,相当于ES6 模块中的export default。这些你可以像这样导入import ... from "..."

因此,当您使用 modules.exports 时,您要么必须将导入更改为:

const mongo = require('./mongo');

或者您可以将导出更改为:

export run

【讨论】:

你不能在 CommonJS 模块中做import mongo from "./mongo";。你的意思是const mongo = await import('./mongo'); 在 CommonJS 模块中不能这样做,但他在 ES6 模块中导入 是的,但是如果他们想通过module.exports导出(“所以当你使用modules.exports...”),那么他们的模块必须转换为一个 CommonJS 模块(虽然使用 ES6 导出会更好) 哦,是的,你是对的......我会改变我的答案

以上是关于在 ES6 中使用 module.exports 导出多个函数的主要内容,如果未能解决你的问题,请参考以下文章

commonjs 与 ES6 模块化

Node.js 和 ES6 中的 module.exports 与 export default

带有 es6 导入的 Module.exports 用于 typescript 中的 webpack.config.ts

exports与module.exports的区别,export与export.defult区别

Vue 中 export default 和 module.exports

ES6的export与Nodejs的module.exports