【Node.js学习 day4——模块化】

模块化介绍

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

模块化初体验

自定义模块 test.js

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

//暴露数据
module.exports = tiemo;

主程序index.js

//引入自定义模块
const tiemo = require('./test.js');
//调用函数
tiemo();

调用:

模块暴露数据

模块暴露数据的方式有两种:

  1. module.exports = value
  2. exports.name = value

使用时有几点注意:

  • module.exports可以暴露任意数据

  • 不能使用exports = value 的形式暴露数据,模块内部module与exports的隐式关系exports = module.exports = {}

    代码示例:
    test.js

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

    function niejiao(){
    console.log('捏脚.........');
    }

    //暴露数据
    module.exports = {tiemo,niejiao};

index.js

//引入自定义模块
const me = require('./test.js');

console.log(me);

导入文件模块

在模块中使用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模块的名字即可,无需加./和.../

    module.exports、exports以及require这些都是CommonJS模块化规范中的内容,而Node.js实现了CommonJS模块化规范。

require导入模块的基本流程

  1. 将相对路径转为绝对路径,定位目标文件

  2. 缓存检测

  3. 读取目标文件代码

  4. 包裹为一个函数并执行(自执行函数)。通过arguments.callee.toString()查看自执行函数

  5. 缓存模块的值

  6. 返回module.exports的值

    function require(file){
    //将相对路径转为绝对路径,定位目标文件
    let absolutePath = path.resolve(__dirname, file);
    //2.缓存监测
    if(caches[absolutePath]){
    return caches[absolutePath];
    }
    //3.读取文件的代码
    let code = fs.readFileSync(absolutePath).toString();
    //4.包裹为一个函数 然后执行
    let module = {};
    let exports = module.exports ={}
    (function (exports, require, module, __filename, __dirname){
    const test = {
    name:'尚硅谷'
    }

         module.exports = test;
    
         //输出
         console.log(arguments.callee.toString());
     })(exports, require, module, __filename, __dirname)
     //5.缓存结果
     caches[absolutePath] = module.exports;
     //6.返回module.exports的值
     return module.exports;
    

    }

    const m = require('./me.js');

CommonJS模块化规范

module.exports、exports以及require这些都是CommonJS模块化规范中的内容。而Node.js是实现了CommonJS模块化规范,二者关系有点像JavaScript与ECMAScript

相关推荐
求知若饥10 分钟前
NestJS 项目实战-权限管理系统开发(六)
后端·node.js·nestjs
ZJ_.15 分钟前
WPSJS:让 WPS 办公与 JavaScript 完美联动
开发语言·前端·javascript·vscode·ecmascript·wps
Code哈哈笑1 小时前
【Java 学习】深度剖析Java多态:从向上转型到向下转型,解锁动态绑定的奥秘,让代码更优雅灵活
java·开发语言·学习
joan_851 小时前
layui表格templet图片渲染--模板字符串和字符串拼接
前端·javascript·layui
还是大剑师兰特1 小时前
什么是尾调用,使用尾调用有什么好处?
javascript·大剑师·尾调用
Watermelo6172 小时前
详解js柯里化原理及用法,探究柯里化在Redux Selector 的场景模拟、构建复杂的数据流管道、优化深度嵌套函数中的精妙应用
开发语言·前端·javascript·算法·数据挖掘·数据分析·ecmascript
QQ同步助手2 小时前
如何正确使用人工智能:开启智慧学习与创新之旅
人工智能·学习·百度
流浪的小新2 小时前
【AI】人工智能、LLM学习资源汇总
人工智能·学习
A懿轩A3 小时前
C/C++ 数据结构与算法【数组】 数组详细解析【日常学习,考研必备】带图+详细代码
c语言·数据结构·c++·学习·考研·算法·数组
一个处女座的程序猿O(∩_∩)O4 小时前
小型 Vue 项目,该不该用 Pinia 、Vuex呢?
前端·javascript·vue.js