Tips1: require.main 的妙用

视频讲解

音频讲解

文字讲解

1、本期 Tip 内容

今天要学习的是 Node.js 的 tips,是关于 require.main === module 这个条件判断语句的用处。

先了解两个前提知识:

  1. 当 Node.js 直接运行一个文件时,require.main 会被设为该文件模块的 module变量。

  2. 在每个模块里面, module 表示指向当前模块的变量对象(可以理解成某种意义上的 this 变量);注意 module 并不是全局对象,是局部变量。

这意味着可以通过 require.main === module 来判断一个文件是否被直接运行。

Node.js 官网 “Accessing the main module” 中有言:

Node.js 官网对 require.main 的解释

简单翻译一下就是:
可以通过 require.main === module 来判断当前文件是否直接被 node.js 执行,比如对 foo.js 文件,如果你执行了 node foo.js,那么这个条件语句结果是 true,如果是被其他文件以 require('./foo') 引用则为 false

2、简单的例子

我们写一个简单的例子来理解,比如我们写一个 plus.js 文件,里面提供了 plus 函数来实现 加法 的功能:

// plus.js
function plus(a, b) {
    return a + b;
}

module.exports = plus;

我们想要快速简单测试该 plus 功能,所以添加一行测试语句放在文末:

// plus.js
...
module.exports = plus;
// 新增一行语句测试 plus 函数功能
console.log('plus: 1 + 2 = ', plus(1, 2));

此时我们直接执行 node plus.js 的确会输出 plus: 1 + 2 = 3 语句,达到我们测试的目的。

不过这样会存在存在一个问题,当正常情况下我们另一个模块 main.js 去引入该 plus.js 文件后,我们去执行 main.js 文件也会执行这条测试代码 —— 很显然这不是我们所想要的。

此时这个 require.main === module 判断语句就派上用场了:

// plus.js
...
module.exports = plus;
// 使用该判断语句
if(require.main === module) {
    console.log('plus: 1 + 2 = ', plus(1, 2));
}

这样其他模块引入当前 plus.js 模块后就不会执行这条测试语句了。

本例代码可前往 这儿 获取

该技巧经常用在代码演示中(或者自测),比如我最近正在看 loopback-next/context example 代码 中的每个 js 文件文末最后都会有这样的代码:

这就是为了方便测试该模块功能,同时也不影响被其他模块引用

       

REFERENCE

   参考文档

  • require.main:官方文档对 require.main 的解释

  • Node.js, require.main === module:如果想直接在 node.js 中运行代码,一般用这个条件

关于「JSCON专栏﹒前端Tips」

前端Tips”专栏,隶属于是 JSCON 专栏系列,设计初衷是快速获取前端小技巧知识,取材广泛,涵盖前端编程诸多领域。设计初衷是快速消费类知识,所以每个 tips 阅读耗时大约 5 分钟。为方便读者在不同场合阅读,每篇 tips 配有视频音频文字,挑自己喜欢方便的就行。

欢迎大家关注我的知识专栏,更多内容等你来挖掘

嘿,请问如何获取往期 tips ?

有两种方式哈:

① 在公众号内回 "tips" + "期号" 就可以。例如:回复 “tips25” 即可获取第 25 期 tips

② 前往网站:https://boycgit.github.io/fe-program-tips,里面提供了搜索功能

微信中外链无法点击,完整版请点击下方的"阅读原文"  


  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值