Node.js使用自己的模块

Node.js使用自己的模块

1.为什么要使用模块

如果你将全部的代码都写入一个文件中,就很难以维护,模块可以让你隔离作用域,将功能进行拆分,逻辑清晰;并且可以请求的复用代码

2.创建并到处模块(CommonJS)

Node.js原生是采用CommonJS规范,使用module.exports或者exports到处内容

2.1基本语法

  • 首先我们创建也给文件夹,modules;我们之前写了一个替换模块的函数,这个模块我们将提取出来

  • 文件夹创建好之后,我们再modules文件夹下创建一个文件叫replaceTemplate.js,我们将函数复制过去,然后使用module.exports导出

js 复制代码
module.exports = (temp,product) => {
    let output = temp.replace(/{%PRODUCTNAME%}/g,product.productName);
    output = output.replace(/{%IMAGE%}/g,product.image);
    output = output.replace(/{%PRICE%}/g,product.price);
    output = output.replace(/{%FROM%}/g,product.from);
    output = output.replace(/{%NUTRIENTS%}/g,product.nutrients);
    output = output.replace(/{%QUANTITY%}/g,product.quantity);
    output = output.replace(/{%DESCRIPTION%}/g,product.description);
    output = output.replace(/{%ID%}/g,product.id);

   if(!product.organic) {
    output = output.replace(/{%NOT_ORGANIC%}/g, 'not-organic');
} else {
    output = output.replace(/{%NOT_ORGANIC%}/g, '');
}

    return output;
}
  • 我们也可以直接使用exports写法
js 复制代码
exports.replaceTemplate = (temp,product) => {
    let output = temp.replace(/{%PRODUCTNAME%}/g,product.productName);
    output = output.replace(/{%IMAGE%}/g,product.image);
    output = output.replace(/{%PRICE%}/g,product.price);
    output = output.replace(/{%FROM%}/g,product.from);
    output = output.replace(/{%NUTRIENTS%}/g,product.nutrients);
    output = output.replace(/{%QUANTITY%}/g,product.quantity);
    output = output.replace(/{%DESCRIPTION%}/g,product.description);
    output = output.replace(/{%ID%}/g,product.id);

   if(!product.organic) {
    output = output.replace(/{%NOT_ORGANIC%}/g, 'not-organic');
} else {
    output = output.replace(/{%NOT_ORGANIC%}/g, '');
}

    return output;
}

3.导入模块

  • 然后就可以导入我们的模块了
js 复制代码
const replaceTemplate = require('./modules/replaceTemplate')
  • 如果你是使用exports的方式来导出模块的,你需要使用将其解构出来
js 复制代码
const {replaceTemplate} = require('./modules/replaceTemplate')

需要解构的原因就是,exports的本质是返回的是这个modules.exports的对象,所以需要将这个属性解构出来

  • 之后会测试一切功能都正常

注意点

  1. 如果你引入没有写任何的扩展,例如const {replaceTemplate} = require('./modules/replaceTemplate'),它会以此尝试replaceTemplate.js,replaceTemplate.json,replaceTemplate.node;
  2. 如果你引入的是一个目录,那么它会自动的寻找该目录下的package.json中的main字段或者直接寻找index.js这个文件;
  3. 每个模块只在第一次require时执行缓存机制,这个特点可能会在你多个文件分享同一个对象的状态的发生错误;
  4. 在模块内部定义的变量是私有的,不会污染全局变量;
  5. 尽量不要设计循环依赖,例如A引入B,B又引入A的这种设计,Node.js 会返回一个尚未执行完毕的不完整导出对象,这种需求最好使用一个第三方公共模块;

4.从Node.js12开始,可以使用ES模块的导入方式

  • 命名导出
js 复制代码
export function replaceTemplate(temp,product) {
    let output = temp.replace(/{%PRODUCTNAME%}/g,product.productName);
    output = output.replace(/{%IMAGE%}/g,product.image);
    output = output.replace(/{%PRICE%}/g,product.price);
    output = output.replace(/{%FROM%}/g,product.from);
    output = output.replace(/{%NUTRIENTS%}/g,product.nutrients);
    output = output.replace(/{%QUANTITY%}/g,product.quantity);
    output = output.replace(/{%DESCRIPTION%}/g,product.description);
    output = output.replace(/{%ID%}/g,product.id);

   if(!product.organic) {
    output = output.replace(/{%NOT_ORGANIC%}/g, 'not-organic');
} else {
    output = output.replace(/{%NOT_ORGANIC%}/g, '');
}

    return output;

}
  • 导入
js 复制代码
import {replaceTemplate} from './modules/replaceTemplate.mjs'

注意:

1.使用ES模块,你必须将所有原先的js文件,该为mjs文件,以告诉node这个是使用ES模块的模式;

2.改为mjs之后,你的fs模块、url模块都需要使用import方式来引入,不能再使用require的方式来引入了!

相关推荐
用户15583199681414 小时前
用Node写一个文件同步CLI工具
node.js
李白的天不白17 小时前
webpack 压缩文件
前端·webpack·node.js
zzzzzz31019 小时前
AI Agent 开发实战:从零构建智能代码助手
react.js·node.js
donecoding21 小时前
用了多年 nvm,我终于找到 Python 的版本管理「答案」:uv
python·node.js·前端工程化
南城雨落21 小时前
uni-app开发经验分享-跨端开发经验总结
javascript·vue.js·node.js
子兮曰2 天前
Node.js v26.1.0 深度解读:FFI、后量子密码与调试器的进化
前端·后端·node.js
大家的林语冰2 天前
Node 2026 发布,JS 三大新功能上线,最后一个奇偶版本
前端·javascript·node.js
Aolith3 天前
从裸奔到加固:我的校园论坛网络安全实战
node.js·全栈
晓杰'3 天前
Balatro后端进阶(1):自定义NestJS WebSocket Adapter实现消息拦截
后端·websocket·typescript·node.js·游戏开发·nestjs·wsadapter
zyl837213 天前
Express快速上手
https·node.js·express