我的前端坑
  • 关于本书
  • CSS JS 常用
    • 常用 CSS 样式
    • 坑爹的 CSS
    • sass 入门
    • canvas 总结
    • 常用 JS 函数
    • 表单和 FormData 对象
    • 水平滑动 tab 居中
    • js 中的 this
    • sse 和 fetch
    • js 原型链与 class 类
  • TypeScript
    • TS 概念
    • interface 与 type
    • interface 接口
    • Ts 配合 ESLint 和 prettier
  • 小程序
    • 常用小程序代码
  • VUE
    • VUE2 小技巧
    • VUE-CLI 中的 NODE_ENV
  • VUE3
    • VUE3 自行构建 sfc 遇到的坑
    • VUE3 v-model 的实现
    • VUE3 使用总结
    • VUE3 ref
  • vite
    • vite
  • http 请求
    • 前端实现下载
    • cors 跨域请求
    • windows hosts 文件
    • err_blocked_by_client 错误
  • 前端工具
    • npm 和 Node
      • 常见问题
      • npmTips
      • package.json 与 package-lock.json
      • npx
      • exports 与 module.exports
      • ESLint
    • VIM
      • vim 常用
    • Git
      • Git 常用命令
      • Git 小 tips
    • express
  • 后端工具
    • mysql 常见问题
    • docker 常见问题
    • docker
  • java
    • java 常用
    • lambda 表达式
    • java 字符串
    • java 泛型
    • java 反射
    • intellij IDEA
    • 多态
    • java 包管理
    • sql 查询语言
    • java 反射
    • java 异常
    • java 集合
    • spring
  • 命令行
    • 命令行 常用
  • 专利撰写 ppt
  • 后台简述
Powered by GitBook
On this page
  • exports 与 module.exports
  • 参考博文

Was this helpful?

  1. 前端工具
  2. npm 和 Node

exports 与 module.exports

exports 与 module.exports

从模块编写角度来看,二者等价

console.log(exports)
console.log(module.exports)
console.log(module.exports === exports)

//  打印结果为:

// {}
// {}
// true

从使用者角度,二者有区别

// 使用 module.exports 语法写模块 exp.js
module.exports = function(){
  console.log('这是用module.exports写的模块')
}

// 引用时用如下方式引用
const expFunc = require('./exp.js)


// 使用 exports 语法写模块 exp.js
exports.expFunc = function(){
  console.log('这是用exports写的模块')
}

// 引用时使用者必须知道该函数的名称
const {expFunc} = require('./exp.js)

看另外一个例子

// 模块 exp1.js
exports = 3.14

// 模块引用
const a = require('./exp1.js')
console.log(a)
//  打印结果:{}


// 模块 exp2.js
module.exports = 3.14

// 模块引用
const a = require('./exp2.js')
console.log(a)
//  打印结果:3.14

总结

在 Node.js 模块里,真正控制模块导出的是 module.exports,exports 只是 module.exports 决定导出一个对象时的一个快捷方式,假 如 module.exports 导出其它类型的数据,比如字符串、数值、函数等等,则 exports 的存在没有意义。这是 Node.js 模块与 CommonJS 差异的一点,在 CommonJS 规范里,是只有 exports,没有 module.exports 的。

参考博文

PreviousnpxNextESLint

Last updated 3 years ago

Was this helpful?

区别 module.exports 与 exports