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的方式来引入了!

相关推荐
见过夏天17 小时前
Node.js 常用命令全攻略
node.js
前端双越老师1 天前
我从 0 开发的 AI Agent 智语项目发布了
前端·node.js·agent
kyriewen2 天前
2026 年了,还在用 Node.js?Bun 迁移实战:20 分钟搞定,附踩坑记录
前端·javascript·node.js
donecoding2 天前
3 条命令搞定闭环 Monorepo:Lerna 版本管理 + 拓扑构建 + 自定义分发
前端·前端框架·node.js
Flynt3 天前
npm v12 来了:allowScripts 默认关闭,我的项目差点跑不起来
安全·npm·node.js
叫我Paul就好4 天前
尝试 Node 搭建后端-开发框架
node.js
风止何安啊6 天前
网课倍速痛点解决:一套前端代码实现自由控速播放器
前端·javascript·node.js
糖拌西瓜皮6 天前
Node.js核心模块实战:文件、路径、HTTP与流处理
javascript·node.js
糖拌西瓜皮6 天前
Node.js工程化实践:包管理、TypeScript配置与代码质量
typescript·node.js
糖拌西瓜皮6 天前
NestJS入门指南:Java开发者的Spring Boot体验
javascript·node.js