node_modules是node.js開發中常用到的一個概念,它被稱作是node.js生態圈的核心,包含了最豐富的第三方插件和庫。在node.js中,要使用一個第三方插件或庫,必須先安裝它,而安裝的過程會將這些插件或庫存儲在node_modules目錄中。
一、node_modules的安裝與使用
node.js提供了npm工具用於進行插件或庫的安裝。npm是node.js社區維護的一個包管理器,同時也是node.js包的註冊中心。我們可以使用npm在終端中安裝想要使用的插件或庫,如下:
npm install <package>
其中,<package>是你希望安裝的插件或庫名稱。例如,安裝express的命令為:
npm install express
安裝完成後,運行程序時,需要在代碼中指定使用哪個插件或庫。使用require函數即可完成引入操作,如下所示:
const express = require('express');
這樣,就可以在代碼中使用express插件了。
二、node_modules的目錄結構
node_modules中的插件或庫是以目錄的形式存儲的,這些目錄大多數情況下都有一個package.json文件。這個文件包含了很多有用的信息,比如插件或庫的名稱、版本、描述、作者等等。此外,這個文件還包含了插件或庫的依賴關係,即它依賴哪些其他插件或庫。
在package.json文件中,dependencies屬性用於列出插件或庫所依賴的其他插件或庫的名稱和版本號。安裝一個插件或庫時,npm會自動下載並安裝這些插件或庫。例如,以下是express的package.json文件示例:
{
"name": "express",
"version": "4.17.1",
"description": "Fast, unopinionated, minimalist web framework for node.",
"keywords": [
"express",
"framework",
"sinatra",
"web",
"rest",
"restful",
"router",
"app",
"api"
],
"dependencies": {
"accepts": "~1.3.7",
"array-flatten": "1.1.1",
"body-parser": "1.19.0",
"content-disposition": "0.5.3",
"content-type": "~1.0.4",
"cookie": "0.4.0",
"cookie-signature": "1.0.6",
"debug": "2.6.9",
"depd": "~1.1.2",
"encodeurl": "~1.0.2",
"escape-html": "~1.0.3",
"etag": "~1.8.1",
"finalhandler": "1.1.1",
"fresh": "0.5.2",
"merge-descriptors": "1.0.1",
"methods": "~1.1.2",
"on-finished": "~2.3.0",
"parseurl": "~1.3.3",
"path-to-regexp": "0.1.7",
"proxy-addr": "~2.0.5",
"qs": "6.7.0",
"range-parser": "~1.2.1",
"safe-buffer": "5.1.2",
"send": "0.17.1",
"serve-static": "1.14.1",
"setprototypeof": "1.1.0",
"statuses": "~1.5.0",
"type-is": "~1.6.18",
"utils-merge": "1.0.1",
"vary": "~1.1.2"
}
}
三、通過dotenv使用環境變數
dotenv是一個輕量級的node.js模塊,用於載入環境變數到process.env中。一般來說,dotenv配合node.js中的process.env來使用,可以用於指定敏感數據或運行環境的配置信息。接下來,我們演示一下如何使用dotenv模塊。
首先,我們需要安裝dotenv模塊:
npm install dotenv
然後,在需要使用環境變數的js文件中,引入dotenv模塊並調用config()方法即可,如下:
require('dotenv').config();
這樣,dotenv會自動讀取項目根目錄下的.env文件,並將其中的變數注入到process.env中。例如,如果.env文件內容如下:
# .env
DB_HOST=localhost
DB_USER=root
DB_PASS=s1mpl3
那麼,調用config()方法後,process.env的值就會類似如下:
{
DB_HOST: "localhost",
DB_USER: "root",
DB_PASS: "s1mpl3"
}
在代碼中,我們可以通過process.env來獲取相應的變數值:
const dbHost = process.env.DB_HOST;
const dbUser = process.env.DB_USER;
const dbPass = process.env.DB_PASS;
這種方式可以有效地保護程序中出現的敏感信息,比如資料庫密碼、加密密鑰等等。
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/290841.html