Node.js NPM Tutorial: Create, Publish, Extend & Manage

 来源    2020-05-23    1  

A module in Node.js is a logical encapsulation of code in a single unit. It's always a good programming practice to always segregate code in such a way that makes it more manageable and maintainable for future purposes. That's where modules in Node.js comes in action.

Since each module is an independent entity with its own encapsulated functionality, it can be managed as a separate unit of work.


In this tutorial, will learn-

What are modules in Node.js?

As stated earlier, modules in Node.js are a way of encapsulating code in a separate logical unit. There are many ready made modules available in the market which can be used within Node.js.


Below are some of the popular modules which are used in a Node.js application

  1. Express framework – Express is a minimal and flexible Node.js web application framework that provides a robust set of features for the web and mobile applications.

    Express是一个最小且灵活的Node.js Web应用程序框架,为Web和移动应用程序提供了一组强大的功能

  2. Socket.io - Socket.IO enables real-time bidirectional event-based communication. This module is good for creation of chatting based applications.


  3. Pug - Pug is a high-performance template engine and implemented with JavaScript for node and browsers.


  4. MongoDB - The MongoDB Node.js driver is the officially supported node.js driver for MongoDB.

    MongoDB Node.js驱动程序是MongoDB官方支持的node.js驱动程序。

  5. Restify - restify is a lightweight framework, similar to express for building REST APIs

    restify是一个轻量级框架,类似于用于构建REST API的表达

  6. Bluebird - Bluebird is a fully-featured promise library with a focus on innovative features and performance

Using modules in Node.js

In order to use modules in a Node.js application, they first need to be installed using the Node package manager.

为了在Node.js应用程序中使用模块,首先需要使用Node软件包管理器来安装它们。下面的命令行显示了如何安装“ express”模块。

The below command line shows how a module "express" can be installed.

npm install express

  • The above command will download the necessary files which contain the "express modules" and take care of the installation as well

    上面的命令将下载包含“ express modules”的必要文件,并负责安装

  • Once the module has been installed, in order to use a module in a Node.js application, you need to use the 'require' keyword. This keyword is a way that Node.js uses to incorporate the functionality of a module in an application.


    Let's look at an example of how we can use the "require" keyword. The below "Guru99" code example shows how to use the require function

    让我们看一个示例,说明如何使用“ require”关键字。下面的“ Guru99”代码示例显示了如何使用require函数


    const express = require('express');
    const app = express();
    app.set('view engine','pug');
    app.get('/',function(req,res) {
    const server = app.listen(3000,function() {
1. In the first statement itself, we are using the "require" keyword to include the express module. The "express" module is an optimized JavaScript library for Node.js development. This is one of the most commonly used Node.js modules.
在第一个语句本身中,我们使用“ require”关键字来包含Express模块。“ express”模块是用于Node.js开发的优化的JavaScript库。这是最常用的Node.js模块之一
2. After the module is included, in order to use the functionality within the module, an object needs to be created. Here an object of the express module is created.
3. Once the module is included using the "require" command and an "object" is created, the required methods of the express module can be invoked. Here we are using the set command to set the view engine, which is used to set the templating engine used in Node.js.
一旦使用“ require”命令将模块包括在内并创建了“对象”,便可以调用快速模块的所需方法。在这里,我们使用set命令设置视图引擎,该视图引擎用于设置Node.js中使用的模板引擎
Note:(Just for the reader's understanding; a templating engine is an approach for injecting values in an application by picking up data from data files. This concept is pretty famous in Angular JS wherein the curly braces {{ key }} is used to substitutes values in the web page. The word 'key' in the curly braces basically denotes the variable which will be substituted by a value when the page is displayed.)
注意:模板引擎是一种通过从数据文件中拾取数据来在应用程序中注入值的方法。这个概念在Angular JS中非常有名,其中花括号{{key}}用于替换网页中的值。大括号中的“键”一词基本上表示在显示页面时将由值替换的变量。)
4. Here we are using the listen to method to make the application listen on a particular port number.

Creating NPM modules
Node.js has the ability to create custom modules and allows you to include those custom modules in your Node.js application.
Let's look at a simple example of how we can create our own module and include that module in our main application file. Our module will just do a simple task of adding two numbers.
Let's follow the below steps to see how we can create modules and include them in our application.

Step 1) Create a file called "Addition.js" and include the below code. This file will contain the logic for your module.

Below is the code which would go into this file;

// 上图代码为Node.js V8.4.0
// 以下代码为Node.js V12.16.3
module.exports.AddNumber = (a, b) => {
    return a + b;

Step 2) Create a file called "app.js," which is your main application file and add the below code

// 上图代码为Node.js V8.4.0
// 以下代码为Node.js V12.16.3
const Addition = require('./Addition')
console.log(Addition.AddNumber(1, 2));
  1. We are using the "require" keyword to include the functionality in the Addition.js file.

  2. Since the functions in the Addition.js file are now accessible, we can now make a call to the AddNumber function. In the function, we are passing 2 numbers as parameters. We are then displaying the value in the console.


  • When you run the app.js file, you will get an output of value 3 in the console log.
  • The result is because the AddNumber function in the Addition.js file was called successfully, and the returned value of 3 was displayed in the console.

Note: - We are not using the "Node package manager" as of yet to install our Addition.js module. This is because the module is already part of our project on the local machine. The Node package manager comes in the picture when you publish a module on the internet, which we see in the subsequent topic.

Extending modules

When creating modules, it is also possible to extend or inherit one module from another.


In modern-day programming, it's quite common to build a library of common modules and then extend the functionality of these common modules if required.


Let's look at an example of how we can extend modules in Node.js.


Step 1) Create the base module.

In our example, create a file called "Tutorial.js" and place the below code.

In this code, we are just creating a function which returns a string to the console. The string returned is "Guru99 Tutorial".

module.exports.tutorial = () => {
    console.log('Guru99 Tutorial');

Step 2) Next, we will create our extended module. Create a new file called "NodeTutorial.js" and place the below code in the file.

const Tutor = require('./Tutorial');

module.exports.NodeTutorial = () => {
    console.log('Node Tutorial');

Note, the following key points about the above code

  1. We are using the "require" function in the new module file itself. Since we are going to extend the existing module file "Tutorial.js", we need to first include it before extending it.
  2. We then create a function called "Nodetutorial." This function will do 2 things,
  • It will send a string "Node Tutorial" to the console.
  • It will send the string "Guru99 Tutorial" from the base module "Tutorial.js" to our extended module "NodeTutorial.js".

Step 3) Create your main app.js file, which is your main application file and include the below code.

const localTutor = require('./NodeTutorial');


Publishing NPM(Node Package Manager) Modules

One can publish their own module to their own Github repository.

By publishing your module to a central location, you are then not burdened with having to install yourself on every machine that requires it.

Instead, you can use the install command of npm and install your published npm module.

The following steps need to be followed to publish your npm module

Step 1) Create your repository on GitHub (an online code repository management tool). It can be used for hosting your code repositories.


Step 2) You need to tell your local npm installation on who you are. Which means that we need to tell npm who is the author of this module, what is the email id and any company URL, which is available which needs to be associated with this id. All of these details will be added to your npm module when it is published.

The below commands sets the name, email and URL of the author of the npm module.

npm set init.author.name "Unity."

npm set init.author.email "guru99@gmail.com "

npm set init.author.url http://Guru99.com

Step 3) The next step is to login into npm using the credentials provided in the last step. To login, you need to use the below command

npm login

Step 4) Initialize your package – The next step is to initialize the package to create the package.json file. This can be done by issuing the below command

npm init

When you issue the above command, you will be prompted for some questions. The most important one is the version number for your module.

Step 5) Publish to GitHub – The next step is to publish your source files to GitHub. This can be done by running the below commands.

发布到GitHub –下一步是将源文件发布到GitHub。可以通过运行以下命令来完成

git add.
git commit -m "Initial release"
git tag v0.0.1 
git push origin master --tags

Step 6) Publish your module – The final bit is to publish your module into the npm registry. This is done via the below command.


npm publish

Managing third party packages with npm

As we have seen, the "Node package manager" has the ability to manage modules, which are required by Node.js applications.

如我们所见,“ Node包管理器”具有管理Node.js应用程序所需的模块的能力

Let's look at some of the functions available in the node package manager for managing modules

  1. Installing packages in global mode – Modules can be installed at the global level, which just basically means that these modules would be available for all Node.js projects on a local machine. The example below shows how to install the "express module" with the global option.

    以全局模式安装软件包–模块可以在全局级别安装,这基本上意味着这些模块可用于本地计算机上的所有Node.js项目。下面的示例显示了如何使用全局选项安装“ express模块”。

    npm install express –global

    The global option in the above statement is what allows the modules to be installed at a global level.


  2. Listing all of the global packages installed on a local machine. This can be done by executing the below command in the command prompt


    npm list --global

    Below is the output which will be shown, if you have previously installed the "express module" on your system.

    如果您先前在系统上安装了“ express模块”,则将显示以下输出

    Here you can see the different modules installed on the local machine.

  1. Installing a specific version of a package – Sometimes there may be a requirement to install just the specific version of a package. Once you know package name and the relevant version that needs to be installed, you can use the npm install command to install that specific version.

The example below shows how to install the module called underscore with a specific version of 1.7.0

npm install underscore@1.7.0

  1. Updating a package version – Sometimes you may have an older version of a package in a system, and you may want to update to the latest one available in the market. To do this, one can use the npm update command. The example below shows how to update the underscore package to the latest version

npm update underscore

  1. Searching for a particular package – To search whether a particular version is available on the local system or not, you can use the search command of npm. The example below will check if the express module is installed on the local machine or not.


npm search express

  1. Uninstalling a package – The same in which you can install a package, you can also uninstall a package. The uninstallation of a package is done with the uninstallation command of npm. The example below shows how to uninstall the express module

npm uninstall express

What is the package.json file

The "package.json" file is used to hold the metadata about a particular project. This information provides the Node package manager the necessary information to understand how the project should be handled along with its dependencies.

“ package.json”文件用于保存有关特定项目的元数据。此信息为Node包管理器提供了必要的信息,以了解应如何处理项目及其依赖项

The package.json files contain information such as the project description, the version of the project in a particular distribution, license information, and configuration data.


The package.json file is normally located at the root directory of a Node.js project.


Let's take an example of how the structure of a module looks when it is installed via npm.

The below snapshot shows the file contents of the express module when it is included in your Node.js project. From the snapshot, you can see the package.json file in the express folder.

If you open the package.json file, you will see a lot of information in the file.

Below is a snapshot of a portion of the file. The express@~4.13.1 mentions the version number of the express module being used.


  • A module in Node.js is a logical encapsulation of code in a single unit. Separation into modules makes code more manageable and maintainable for future purposes


  • There are many modules available in the market which can be used within Node.js such as express, underscore, MongoDB, etc.

  • The node package manager (npm) is used to download and install modules which can then be used in a Node.js application.

  • One can create custom NPM modules, extend these modules, and also publish these modules.


  • The Node package manager has a complete set of commands to manage the npm modules on the local system such as the installation, un-installation, searching, etc.

  • The package.json file is used to hold the entire metadata information for an npm module.

node.js – npm运行缓慢
问答我曾经通过Makefile运行各种命令但是对于nodejs项目,package.json是一个更合适的地方. 通过npm运行命令可以很好地工作,但与命令时间执行相比非常慢. $time ./node_ ...
node.js – npm install:使用全局包(如果存在),而不是安装两次
问答将npm install与package.json文件一起使用时,如何让它使用符合条件的全局安装包,而不是再次在本地下载和安装包? 我知道link,但是有办法做我正在描述的事情吗?::为特定模块集执行 ...
node.js – npm默认安装保存
问答它发生了很多次,我忘了在安装节点模块时添加–save.有没有办法在默认情况下附加此选项?这样每当我输入npm install该包被添加到package.json中的依赖项.::从npm5起,npm默认 ...
问答我是Node.js的新手 有人可以解释一下如何安装Node.js,npm和socket.io. 谢谢.::1 ..转到http://nodejs.org,点击安装按钮 2 ..下载节点并安装它 3.在 ...
node.js – npm package.json OS特定脚本
问答我想创建一个package.json构建脚本,该脚本在从Windows,Linux,Mac运行时执行稍微不同的命令集. 问题是我无法找到一种方法将它放在package.json文件中,该文件将在每个系 ...
node.js – NPM运行并行任务,但等到资源可用于运行第二个任务
问答在npm中,如何运行两个或多个并行任务,但是等待第一个任务将创建的资源可供第二个任务使用,等等? 例子(概念): npm run task1 & waitfor task1 then task ...
node.js – npm install:有没有办法忽略package.json中的特定依赖项
问答我目前正在尝试为包含本地依赖项的node.js项目创建一个docker容器.这似乎导致docker的问题,所以作为一种解决方法我试图只复制本地依赖项文件夹,并忽略它们在package.json文件中的 ...
node.js – NPM:不要为npm包安装嵌套的可选依赖项
问答我正在创建一个我想发布到NPM的软件包A. A依赖于包B,后者又依赖于包C. C然后有两个可选的本地依赖D和E.我知道我没有用于可选的依赖关系D和E,并且不想要有人安装我的包时尝试安装它们. 我知道你 ...
node.js – npm package.json操作系统特定的依赖关系
问答有没有办法在npm package.json文件中指定操作系统特定的依赖关系? 例如,如果用户正在运行Linux,我只想安装'dbus'(https://npmjs.org/package/dbus) ...
node.js – npm link“文件被标记为可执行文件但无法由操作系统运行.”
问答所以我用package.json创建了一个cli,它指定了一个bin文件. 我发现了它的链接.然后我在我的桌面上创建了一个新文件夹和npm链接foocli,它将其安装到该目录的node_modules ...
node.js – “npm update -g”,“npm upgrade -g”,“npm install -g npm”和“n stable”之间有什么区别?
问答我的npm似乎已经过时了,所以我似乎可以使用4种方式来更新它: sudo npm update -g # => npm 3.8.6 sudo npm upgrade -g # => npm ...
node.js – npm install module在当前目录下
问答当我跑: npm install my-app 该应用程序安装到node_modules / my-app / - 我也试过 npm install -g my-app 但这也不行. 如何将模块直接安 ...
node.js – npm install中–save和–save-dev的区别是什么?
问答我试图理解,何时何地使用这些标签,我明白一个是开发依赖,另一个是项目依赖,但是当它用于实际项目时,我没有发现任何差异. 我正在寻找一种方法,这将为错误的安装类型抛出错误. 有没有办法做到这一点?::依 ...
node.js – npm不工作,总是得到这个错误 – >错误:找不到模块“我们还在 –
问答我试图安装咕噜在一个mac与优胜美地.节点已安装在最新版本中.如果我在终端中键入"node -v",我得到行v0.12.5.那很好.但是当我想要安装的东西与npm我只得到一个错误- ...
node.js – npm不会在本地安装软件包.怎么了?
问答我想在本地安装软件包,但是npm总是将软件包安装到全局位置.我正在运行以下命令: npm install serialport 我没有.npmrc命令,我没有使用-g标志,所以我不知道为什么它不是在本 ...
node.js – npm本地安装
问答在过去,当我使用npm(> = 1.0)安装软件包时,它们将被安装在本地,但不会再安装. 我的设置: >首先我用nvm安装node.js. >我的操作系统: alfred@alfre ...
node.js – npm install显示最新而不是安装包
问答我在使用npm install时遇到了一些麻烦. npm install package-name工作正常,但是当我手动在package.json文件中添加一个新的依赖项(通过git拉动)然后尝试np ...
node.js – npm WARN install无法安装可选的依赖关系:不支持
问答我收到此警告消息: npm WARN install Couldn't install optional dependency: Unsupported 当我运行命令: $npm i adaro -- ...
node.js – npm:在安装软件包时禁用postinstall脚本
问答是否存在任何npm选项禁用安装后脚本安装包?或者重写package.json的任何字段?::无法仅禁用安装后脚本.但是,您可以使用以下命令禁用所有脚本: $ npm install –ignore-s ...
node.js – npm WARN包作为dev和production依赖项包含在内
问答运行npm install时 我收到了这些警告: npm WARN The package babel-core is included as both a dev and production de ...