JavaScript 模組是一種組織和重複使用 JavaScript 程式碼的方法。使用模組可以將程式碼分解為更小的、可管理的部分,然後可以根據需要在應用程式的其他部分中導入和使用。這種模組化方法有助於維護乾淨的程式碼庫,使其更易於調試,並增強程式碼的可重複使用性。
JavaScript 生態系中有不同的模組系統。 ES 模組 (ESM) 是 ECMAScript 規範中的標準,主要在瀏覽器中使用,並且越來越多地在 Node.js 中得到支援。 CommonJS 是傳統上在 Node.js 中使用的另一個模組系統。
ES 模組 (ESM) 是 JavaScript 中的標準化模組系統,在 ECMAScript 2015 (ES6) 中引入。它們透過啟用不同檔案之間的函數、物件和原語的匯入和匯出來實現更好的程式碼組織和可重複使用性。該模組系統在現代 JavaScript 環境中得到廣泛支持,包括瀏覽器和 Node.js。
匯出與匯入
export 關鍵字標記應該可以從當前模組外部存取的變數和函數,從而允許它們在應用程式的其他部分中重複使用。 import 關鍵字允許從其他模組導入這些功能,從而實現模組化編程和程式碼重用。
命名導出允許從一個模組導出多個項目。每個專案匯入時必須使用與匯出時相同的名稱。
//modules.js const greet = () => { console.log('Hello World'); }; export { greet};
匯入命名匯出時,需要使用與匯出相同的名稱。
import { greet } from './module.js'; greet(); // Hello, World!
預設導出允許每個模組有一個預設導出。該項目可以用任何名稱導入。
//modules.js const greet = () => { console.log('Hello World'); }; export default greet;
導入時預設導出,可以使用任意名稱。
import message from './module.js'; message(); // Hello, World!
在 HTML 中使用模組
在瀏覽器中使用模組時,您需要將它們包含在 HTML 檔案中。您可以在 <script> 中使用 type="module" 屬性。標籤。 <br> </script>
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Js:modules</title> </head> <body> <script type="module" src="main.js"></script> </body> </html>
瀏覽器支援
現代瀏覽器原生支援 JavaScript 模組。這包括 Chrome、Firefox、Safari、Edge 和 Opera。但是,Internet Explorer 等較舊的瀏覽器不支援模組。對於這些,您可能需要使用像 Webpack 這樣的捆綁器或像 Babel 這樣的轉譯器。
在 Node.js 中使用模組
要在 Node.js 中使用 ES 模組,可以使用 .mjs 檔案副檔名或在 package.json 檔案中設定 "type": "module"。
// package.json { "type": "module" }
導入別名
JavaScript 模組中的別名可讓您使用不同的名稱匯入和匯出功能。這對於避免命名衝突或在導入它們的模組的上下文中提供更具描述性的名稱非常有用。
// math.js export function add(a, b) { return a + b; } export function subtract(a, b) { return a - b; }
您可以使用別名匯入具有不同名稱的這些函數:
// main.js import { add as sum, subtract as diff } from './math.js'; console.log(sum(2, 3)); // 5 console.log(diff(5, 3)); // 2
將整個模組匯入為別名
您可以將整個模組匯入為單一別名,這允許您存取命名空間下的所有匯出。
// main.js import * as math from './math.js'; console.log(math.add(2, 3)); // 5 console.log(math.subtract(5, 3)); // 2
動態導入
您也可以使用 import() 函數動態導入模組,該函數傳回一個承諾。這對於程式碼分割和延遲載入很有用。
// main.js const loadModule = async () => { try { const module = await import('./math.js'); console.log(module.add(2, 3)); } catch (error) { console.error('loading error:', error); } }; loadModule();
在此範例中,當呼叫 loadModule 函數時,math.js 模組會動態載入。
CommonJS 是一個主要用於 Node.js 的模組系統。它是 ES Modules 標準化之前的預設模組系統,至今仍在許多 Node.js 專案中廣泛使用。它使用 require() 導入模組和 module.exports 或導出以從模組導出功能。
在CommonJS中,module.exports和exports都用於從模組匯出值。 Exports 本質上是 module.exports 的簡寫,允許使用其中任何一個。但是,通常建議一致使用 module.exports 以避免潛在的混亂或意外行為。
在此範例中,module.exports 被指派了一個函數,因此 app.js 中的 require 呼叫傳回該函數。
// greet.js module.exports = function(name) { return `Hello, ${name}!`; };
// app.js const greet = require('./greet'); console.log(greet('Alice')); // 'Hello, Alice!'
在此範例中,exports 用於向 module.exports 新增屬性。 app.js 中的 require 呼叫傳回一個帶有加法和減法函數的物件。
// math.js exports.add = function(a, b) { return a + b; }; exports.subtract = function(a, b) { return a - b; };
// app.js const math = require('./math'); console.log(math.add(2, 3)); // 5 console.log(math.subtract(5, 2)); // 3
JavaScript 模組提供了許多好處,可以改善程式碼的組織、可維護性和效能。
可重複使用性
模組可讓您編寫可重複使用的程式碼片段,這些程式碼片段可以在應用程式的不同部分甚至不同的專案中匯入和使用。
可維護性
透過將程式碼分解為更小的、獨立的模組,您可以更有效地管理和維護程式碼庫。這使得更新、重構和調試各個模組變得更加容易,而不會影響整個應用程式。
程式碼分割
模組支援程式碼分割,使您可以在需要時僅載入必要的程式碼,從而縮短初始載入時間並提高整體效能。
改良的測試
模組化程式碼更容易測試,因為您可以單獨測試各個模組。這使得測試更加可靠和可維護。
搖樹
像 Webpack 和 Rollup 這樣的現代模組捆綁器可以執行樹搖動,這是一種從最終捆綁中刪除未使用的程式碼的技術,從而產生更小、更有效率的程式碼。
在 JavaScript 開發中,ES 模組的引入標誌著傳統 CommonJS 模組系統的重大轉變。 ES 模組提供了一種標準化且有效的方法來管理依賴關係並提高可維護性。匯出和匯入語法提供了一種清晰簡潔的方式來定義和使用模組,從而促進程式碼庫更好的組織和可讀性。
以上是使用 ES 模組增強 JavaScript 程式碼:匯出、匯入等的詳細內容。更多資訊請關注PHP中文網其他相關文章!