Node.js之模块化学习(2)

1、Node.js中的模块作用域:

对模块的访问限制,可以防止全局变量污染 

2、向外共享模块作用域中的成员:

1、module对象:在每个.js自定义的模块中都有一个module对象,它里边存储了和当前模块有关的信息。 

module.exports={} ,空对象,可以将模块内部的属性暴露出去,供外部使用

在外界使用require导入一个自定义模块的时,得到的就是module.exports所指的对象

module.export.username='aaa'  //在module.export对象上挂载username属性

导出的内容是:{username:'aaa'}

共享成员时的注意点:

使用require()方法导入模块时,导入的结果,永远以module.exports指向的对象为准

3、exports对象

Node提供的exports对象默认情况下,exports和module.exports指向同一个对象,共享的结果,永远以module.exports指向的对象为准

exports = module.exports = {};

4、exports和module.exports的使用误区

时刻谨记:require()模块时,得到的永远是module.exports指向的对象

为了防止混乱,建议不要在同一个模块中同时使用exports 和module.exports

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Node.js中,模块化是一种组织和管理代码的方式,它允许将代码拆分成多个模块,使得代码更可维护、可重用和可测试。以下是在Node.js中进行模块化的几种常见方式: 1. CommonJS模块化: - 使用`require`函数引入其他模块,例如:`const module = require('./module');` - 使用`module.exports`导出模块的功能,例如:`module.exports = { ... }` 示例: ```javascript // module.js const greeting = 'Hello'; function sayHello(name) { console.log(`${greeting}, ${name}!`); } module.exports = { sayHello }; ``` ```javascript // main.js const module = require('./module'); module.sayHello('John'); ``` 2. ES模块化: - 使用`import`语句引入其他模块,例如:`import module from './module';` - 使用`export`关键字导出模块的功能,例如:`export function greet(name) { ... }` 注意:ES模块化需要在Node.js版本12及以上才能原生支持。 示例: ```javascript // module.mjs const greeting = 'Hello'; function sayHello(name) { console.log(`${greeting}, ${name}!`); } export { sayHello }; ``` ```javascript // main.mjs import { sayHello } from './module.mjs'; sayHello('John'); ``` 3. 第三方模块: - 使用`npm`命令安装第三方模块,例如:`npm install module-name` - 使用`require`或`import`语句引入第三方模块,例如:`const module = require('module-name')`或`import module from 'module-name'` 示例: ```javascript // main.js const express = require('express'); const app = express(); ``` 这些是在Node.js中进行模块化的常见方式。你可以根据自己的需求选择适合的模块化方法来组织和管理代码。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值