NodeJs的模塊化和包

来源:https://www.cnblogs.com/gfhcg/archive/2023/03/21/17241140.html
-Advertisement-
Play Games

模塊化的基本概念 什麼是模塊化? 模塊化是解決一個複雜問題時,自頂向下逐層把系統劃分為若幹個模塊的過程,編程中,就是遵守一定規則,把一個大文件拆成獨立並相互依賴的多個小模塊。 模塊化規範 使用什麼樣的語法格式引用模塊和向外暴露成員 CommonJS規範 Node.js 遵循了 CommonJS 的模 ...


模塊化的基本概念

什麼是模塊化?

模塊化是解決一個複雜問題時,自頂向下逐層把系統劃分為若幹個模塊的過程,編程中,就是遵守一定規則,把一個大文件拆成獨立並相互依賴的多個小模塊。

模塊化規範

使用什麼樣的語法格式引用模塊和向外暴露成員

CommonJS規範

Node.js 遵循了 CommonJS 的模塊化規範。其中:

  • 每個模塊內部,module變數代表當前模塊
  • 導入其它模塊使用require()方法
  • 模塊對外共用成員使用 module.exports 對象

ES6 模塊化規範

是瀏覽器端與伺服器端通用的模塊化開發規範。它的出現極大的降低了前端開發者的模塊化學習成本,開發者不需再額外學習 AMD、CMD 或 Commonjs 等模塊化規範。
ES6 模塊化規範中定義:

  • 每個js文件都是一個獨立的模塊
  • 導入其它模塊成員使用 import 關鍵字
  • 向外共用模塊成員使用 export 關鍵字

在Node.js中設置ES6模塊化規範:

  1. 安裝v14.15.1或更高版本的node.js
  2. package.js的根節點添加"type:""module"節點

Node.js中的模塊化

Node.js中模塊的分類

  • 內置模塊:官方提供的fs、path、http等
  • 自定義模塊:用戶創建的每個.js文件,都是自定義模塊
  • 第三方模塊:由第三方開發的,需要下載的模塊

載入模塊

文章以CommonJS規範為例

//內置模塊
const http = require('http')
//自定義模塊
const custom = require('./custom.js')//尾碼名可以省略
//第三方模塊
const moment = require('moment')

註意:當使用require載入時,會執行被載入模塊的代碼

模塊作用域

在自定義模塊中定義的變數和方法等成員,只能在當前模塊被訪問,防止全局變數污染的問題

//username.js
const username='張三'

function sayHello(){
    console.log("大家好,我是"+username)
}

//test.js
const custom=require('./username')
console.log(custom)//輸出:{} 空對象

向外共用成員

module對象

每個.js自定義模塊中都有一個module對象,它裡面存儲了和當前模塊有關的信息

module.exports對象

在自定義模塊中,可以使用它將模塊內的成員共用出去,當使用require()方法導入時,得到的就是module.exports所指的對象

//username.js
module.exports.username = '張三'
module.exports.sayHello = function () {
    console.log("大家好,我是" + username)
}

註意:

  • module.exports預設指向空對象
  • 使用require()方法導入的結果,以module.exports指向的對象為準

exports對象

為了簡化,Node提供了exports對象。預設情況下,exportsmodule.exports指向同一個對象。

exports.username= '張三'
module.exports={
    gender:'男',
    age:22
}
//{gender:'男',age:22}
module.exports.username= '張三'
exports={
    gender:'男',
    age:22
}
//{username:'張三'}
  • 使用require()方法導入的結果,永遠以module.exports指向的對象為準
  • 防止混亂,不要在同一個模塊中同時使用exportsmodule.exports

npm和包

在Node.js中第三方模塊叫做,來自於第三方個人或團隊,免費且開源。

包基於內置模塊封裝出來,提供了更高級、更方便的API,極大的提高了開發效率。

包的下載

  • https://www.npmis.com/ 網站上搜索自己所需要的包
  • 從https://registry.npmis.org/ 伺服器上下載自己需要的包

使用npm包管理工具(Node Package Manager)

npm install 包的完整名稱
npm i 包的完整名稱 -g//全局安裝
npm install [email protected]

npm uninstall 包的完整名稱

node_modules文件夾用來存放所有已安裝到項目中的包

package-lock.json配置文件用來記錄node_modules目錄下每一個包的下載信息

包的版本號:“點分十進位”

第一位數字:大版本

第二位數字:功能版本

第三位數字:Bug修複版本

(只要前面的版本號增長,後面歸零)

包管理配置文件

npm規定,項目根目錄中,必須提供一個package.json的包管理配置文件

npm init -y//快速新建package.json

dependencies節點

專門記錄使用npm insatll命令安裝了哪些包

npm install
//執行該命令,npm會讀取package.json中的dependencies節點,一次性下載所有的包

devDependencies節點

如果某些包只在開發中用到,建議安裝在devDependencies節點

npm i 包的完整名稱 -D
npm i 包的完整名稱 --save-dev

包下載慢的問題

切換npm的下包鏡像源

npm config get registry //查看當前鏡像源
npm config set registry=xxxxxxxxxx//切換鏡像源

nrm工具

npm i nrm -g
nrm ls//查看所有鏡像源
nrm use taobao//切換鏡像源

包的分類

項目包和全局包、開發依賴包和核心依賴包

規範的包結構

  1. 包必須以單獨的目錄出現
  2. 包的頂級目錄必須包含package.json這個包配置文件
  3. package.json必須包含nameversionmain這三個屬性,分別代表包的名字、版本號、包的入口


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 攔截器&文件上傳 1.攔截器-Interceptor 1.1攔截器概念 攔截器 攔截器(Interceptor):是一種動態攔截方法調用的機制,在SpringMVC中動態攔截控制器方法的執行。在SpringBoot中,攔截器是開發的常用手段,要用來登錄驗證、性能檢查、日誌記錄等 (1)SpringB ...
  • 1 C++初識 1.1 變數 作用:給一段指定的記憶體空間起名,方便操作這段記憶體 **註意:**C++在創建變數時,必須給變數一個初始值,否則會報錯 1.2 常量 作用:用於記錄程式中不可更改的數據 C++定義常量兩種方式 #define 巨集常量: #define 常量名 常量值 通常在文件上方定義, ...
  • 以下是一個基於C語言和Win32API的記憶體掃描器的實現代碼 首先定義一個結構體MEMBLOCK,用來存儲記憶體塊的信息 點擊查看代碼 typedef struct _MEMBLOCK { HANDLE hProcess; //進程句柄 PVOID addr; //記憶體塊地址 int size; // ...
  • 一、PHP簡介 Hypertext Preprocessor,又稱為超文本預處理器(HTML為超文本標簽語言),就是我們所說的PHP。它是一種糅雜百家的後臺語言,在PHP中,可以見到C、Java等語言的寫法和它自創的一些寫法,這也就是為什麼說學過其他語言的人會比較容易接受PHP。 PHP開發時需要去 ...
  • 巨集定義是什麼 巨集定義(macro definition)是 C/C++ 中的一種預處理指令,可以在編譯之前替換源代碼中的一些文本。簡單來說就是用巨集自定義了一些其它符號,這些符號在使用時全等於被替換的內容。 #define DATE "2023_01_20" #define FILE_NUM 250 ...
  • 說明 使用 VLD 記憶體泄漏檢測工具輔助開發時整理的學習筆記。 1. 使用前的準備 參考本人另一篇博客 安裝 Visual Leak Detector 下載 vld-2.5.1-setup.exe 並按步驟安裝 VLD。這一種使用方式的特點是,在一臺電腦上安裝完成後,需在項目 pro 文件中指明庫及 ...
  • 伺服器渲染技術-Thymeleaf 1.基本介紹 官方線上文檔:Read online 文檔下載:Thymeleaf 3.1 PDF, EPUB, MOBI Thymeleaf 是什麼 Thymeleaf是一個現代的伺服器端Java模板引擎,適用於Web和獨立環境,能夠處理HTML,XML,Java ...
  • ###1.起因: 工作中對接平臺需要將設備的GPS數據傳給平臺,但是平臺採用的不是回調函數將數據直接作為參數返回而是格式化的字元串命令,所以需要將double類型的gps數據格式化輸出到字元串中,項目中之前採用的是sprintf進行格式化輸出,但是通過列印對比發現有精度損失,所以改成先放大數據100 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...