node学习(四) 模块化

一、介绍

1.1 什么是模块化与模块 ?

将一个复杂的程序文件依据一定规则(规范)拆分成多个文件的过程称之为 模块化
其中拆分出的 每个文件就是一个模块 ,模块的内部数据是私有的,不过模块可以暴露内部数据以便其他模块使用
1.2 什么是模块化项目 ?
编码时是按照模块一个一个编码的, 整个项目就是一个模块化的项目
1.3 模块化好处
        1. 防止命名冲突
        2. 高复用性
        3. 高维护性

二、模块暴露数据

2.1 模块初体验

可以通过下面的操作步骤,快速体验模块化
1、创建me.js  
在me.js中通过module.exports暴露tiemo方法
function tiemo(){
  console.log('贴膜...');
}

module.exports = tiemo

2、创建index.js

在index.js中通过引入并使用tiemo方法

const tiemo1 = require('./me.js')

tiemo1()

2.2 暴露数据

模块暴露数据的方式有两种:
1. module.exports = value
2. exports.name = value

 ps:

使用时有几点注意:
        module.exports 可以暴露 任意 数据
        不能使用 exports = value 的形式暴露数据,只能通过( exports.name = value )的方式暴露数据,因为模块内部 module.exports  与 exports 的隐式关系【指向同一个地址】
exports = module.exports = {} require 引入时 返回的是目标模块中 module.exports 的值

 1、创建me.js  

function tiemo(){
  console.log('贴膜...');
}

function xiujiao(){
  console.log('修脚...');
}
// 暴露方式一
// module.exports = {
//   tiemo,
//   xiujiao
// }

// 暴露方式二
exports.tiemo = tiemo
exports.xiujiao = xiujiao

2、创建index.js

const { tiemo, xiujiao } = require('./me.js')

tiemo() // 贴膜...
xiujiao() // 修脚...

三、导入(引入)模块 

在模块中使用 require 传入文件路径即可引入文件
const test = require ( './me.js' );

 require 使用的一些注意事项:

1. 对于自己创建的模块,导入时路径建议写 相对路径 ,且不能省略 ./ ../
2. js json 文件导入时可以不用写后缀, c/c++ 编写的 node 扩展文件也可以不写后缀,但是一般用不到
3. 如果导入其他类型的文件,会以 js 文件进行处理
4. 如果导入的路径是个 文件夹 ,则会 首先 检测该文件夹下 package.json 文件中 main 属性对应的文件,
如果存在则导入,反之如果文件不存在会报错。
如果 main 属性不存在,或者 package.json 不存在,则会尝试导入文件夹下的 index.js
index.json
如果还是没找到,就会报错
5. 导入 node.js 内置模块时,直接 require 模块的名字即可,无需加 ./ ../

四、导入模块的基本流程 

这里我们介绍一下 require 导入 自定义模块 的运行基本流程
1. 将相对路径转为绝对路径,定位目标文件
2. 缓存检测
3. 读取目标文件代码
4. 包裹为一个函数并执行(自执行函数)。通过 arguments.callee.toString() 查看自执行函数
5. 缓存模块的值
6. 返回 module.exports 的值

五、CommonJS 规范 

module.exports exports 以及 require 这些都是 CommonJS 模块化规范中的内容。
Node.js 是实现了 CommonJS 模块化规范,二者关系有点像 JavaScript ECMAScript
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值