浏览器支持

现代浏览器原生支持 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.jsexport function add(a, b) {   return a   b;} export function subtract(a, b) {   return a - b;}

您可以使用别名导入具有不同名称的这些函数:

// main.jsimport { add as sum, subtract as diff } from \\'./math.js\\';console.log(sum(2, 3)); // 5console.log(diff(5, 3)); // 2

将整个模块导入为别名

您可以将整个模块导入为单个别名,这允许您访问命名空间下的所有导出。

// main.jsimport * as math from \\'./math.js\\';console.log(math.add(2, 3)); // 5console.log(math.subtract(5, 3)); // 2

动态导入

您还可以使用 import() 函数动态导入模块,该函数返回一个承诺。这对于代码分割和延迟加载很有用。

// main.jsconst 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 (CJS)

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.jsmodule.exports = function(name) {   return `Hello, ${name}!`;};
// app.jsconst greet = require(\\'./greet\\');console.log(greet(\\'Alice\\')); // \\'Hello, Alice!\\'

在此示例中,exports 用于向 module.exports 添加属性。 app.js 中的 require 调用返回一个带有加法和减法函数的对象。

// math.jsexports.add = function(a, b) {   return a   b;};exports.subtract = function(a, b) {   return a - b;};
// app.jsconst math = require(\\'./math\\');console.log(math.add(2, 3)); // 5console.log(math.subtract(5, 2)); // 3

JavaScript 模块提供了许多好处,可以改善代码的组织、可维护性和性能。

结论

在 JavaScript 开发中,ES 模块的引入标志着传统 CommonJS 模块系统的重大转变。 ES 模块提供了一种标准化且有效的方法来管理依赖关系并提高可维护性。导出和导入语法提供了一种清晰简洁的方式来定义和使用模块,从而促进代码库更好的组织和可读性。

","image":"http://www.luping.net/uploads/20240731/172238652866a988605a468.jpg","datePublished":"2024-07-31T08:42:07+08:00","dateModified":"2024-07-31T08:42:07+08:00","author":{"@type":"Person","name":"luping.net","url":"https://www.luping.net/articlelist/0_1.html"}}
」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 使用 ES 模組增強 JavaScript 程式碼:匯出、匯入等

使用 ES 模組增強 JavaScript 程式碼:匯出、匯入等

發佈於2024-07-31
瀏覽:274

Enhancing JavaScript Code with ES Modules: Export, Import, and Beyond

JavaScript 模块是组织和重用 JavaScript 代码的一种方式。使用模块可以将代码分解为更小的、可管理的部分,然后可以根据需要在应用程序的其他部分中导入和使用。这种模块化方法有助于维护干净的代码库,使其更易于调试,并增强代码的可重用性。

ES 模块与 CommonJS

JavaScript 生态系统中有不同的模块系统。 ES 模块 (ESM) 是 ECMAScript 规范中的标准,主要在浏览器中使用,并且越来越多地在 Node.js 中得到支持。 CommonJS 是传统上在 Node.js 中使用的另一个模块系统。

ES 模块 (ESM)

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 文件中。您在




   Js:modules

浏览器支持

现代浏览器原生支持 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 (CJS)

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 模块提供了一种标准化且有效的方法来管理依赖关系并提高可维护性。导出和导入语法提供了一种清晰简洁的方式来定义和使用模块,从而促进代码库更好的组织和可读性。

版本聲明 本文轉載於:https://dev.to/kda/enhancing-javascript-code-with-es-modules-export-import-and-beyond-1d5?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • Next.js - 概述
    Next.js - 概述
    本文作為初學者友好的指南和使用 Next.js 的步驟。 Next.js 是一個用於建立 Web 應用程式的靈活框架。相反,它是一個建立在 Node.js 之上的 React 框架。 設定您的 Next.js 專案 要啟動新的 Next.js 項目,您需要在電腦上安裝 Node.js。 安裝 ...
    程式設計 發佈於2024-11-02
  • 如何在程式碼中使用 Unsplash 圖片
    如何在程式碼中使用 Unsplash 圖片
    身為從事新 SaaS 專案的開發人員,我需要直接透過 URL 連結一些 Unsplash 圖片。 最初,我看到一篇推薦使用 https://source.unsplash.com/ API 的文章(連結)。但是,此方法不再有效,僅從 URL 欄位複製連結並不能提供嵌入所需的直接圖像 URL。 h...
    程式設計 發佈於2024-11-02
  • 如何合併關聯數組、處理缺失鍵、填滿預設值?
    如何合併關聯數組、處理缺失鍵、填滿預設值?
    合併多個關聯數組並添加具有預設值的缺失列將關聯數組與不同的鍵集組合起來創建統一的數組可能具有挑戰性。這個問題探索了一種實現此目的的方法,所需的輸出是一個數組,其中鍵被合併,缺失的列用預設值填充。 為了實現這一點,建議結合使用 array_merge 函數精心設計的鍵數組:$keys = array(...
    程式設計 發佈於2024-11-02
  • 透過 testcontainers-go 和 docker-compose 來利用您的測試套件
    透過 testcontainers-go 和 docker-compose 來利用您的測試套件
    Welcome back, folks! Today, we will cover the end-to-end tests in an intriguing blog post. If you've never written these kinds of tests or if you stri...
    程式設計 發佈於2024-11-02
  • 以下是一些適合您文章的基於問題的標題:

**直接簡潔:**

* **如何在Windows控制台中正確顯示UTF-8字元? ** **
* **為什麼傳統方法無法顯示
    以下是一些適合您文章的基於問題的標題: **直接簡潔:** * **如何在Windows控制台中正確顯示UTF-8字元? ** ** * **為什麼傳統方法無法顯示
    在Windows 控制台中正確顯示UTF-8 字元使用傳統方法在Windows 控制台中顯示UTF-8 字元的許多嘗試均失敗正確渲染擴充字元。 失敗嘗試:一個使用 MultiByteToWideChar() 和 wprintf() 的常見方法被證明是無效的,只留下 ASCII 字元可見。此外,使用 ...
    程式設計 發佈於2024-11-02
  • ReactJS 的模擬介紹
    ReactJS 的模擬介紹
    ReactJS 19:重要部份 並發模式增強: ReactJS 19 中最大的改進是並發模式,它不僅在應用程式自身更新時保持UI 平滑和響應靈敏,而且還確保了無縫界面,尤其是在復雜的過渡(例如動畫)時。 改進的伺服器元件: 在 Python 的引領下,ReactJ...
    程式設計 發佈於2024-11-02
  • 首屆DEV網頁遊戲挑戰賽評審
    首屆DEV網頁遊戲挑戰賽評審
    我被要求對DEV團隊9月份組織的第一屆網頁遊戲挑戰賽提交的參賽作品進行評判,結果在10月初發布。 我們幾個月來一直在 DEV 上組織挑戰(迷你黑客馬拉松),併計劃宣布我們的第一個網頁遊戲挑戰。鑑於您在遊戲社群 和 dev.to 的專業知識和參與度,我們想知道您是否有興趣成為客座評審。 誰能對此說...
    程式設計 發佈於2024-11-02
  • 購買經過驗證的現金應用程式帳戶:安全可靠的交易
    購買經過驗證的現金應用程式帳戶:安全可靠的交易
    Buying verified Cash App accounts is not recommended. It can lead to security risks and potential account bans. If you want to more information just k...
    程式設計 發佈於2024-11-02
  • 為什麼 `std::function` 缺乏相等比較?
    為什麼 `std::function` 缺乏相等比較?
    揭開std::function 的等式可比性之謎難題:為什麼是std::&&]難題:為什麼是std:: function,現代C 程式碼庫的一個組成部分,不具備相等比較功能?這個問題從一開始就困擾著程式設計師,導致管理可呼叫物件集合的混亂和困難。 早期的歧義:在C 語言的早期草案中11 標準中,op...
    程式設計 發佈於2024-11-02
  • JavaScript 類型檢查 |程式設計教學
    JavaScript 類型檢查 |程式設計教學
    介紹 本文涵蓋以下技術技能: 在本實驗中,我們將探索一個 JavaScript 函數,該函數檢查提供的值是否屬於指定類型。我們將使用 is() 函數,它利用建構子屬性和 Array.prototype.includes() 方法來確定值是否屬於指定類型。本實驗將幫助您更了解 Jav...
    程式設計 發佈於2024-11-02
  • 使用 Streamlit 將機器學習模型部署為 Web 應用程式
    使用 Streamlit 將機器學習模型部署為 Web 應用程式
    介绍 机器学习模型本质上是一组用于进行预测或查找数据模式的规则或机制。简单地说(不用担心过于简单化),在 Excel 中使用最小二乘法计算的趋势线也是一个模型。然而,实际应用中使用的模型并不那么简单——它们通常涉及更复杂的方程和算法,而不仅仅是简单的方程。 在这篇文章中,我将首先构...
    程式設計 發佈於2024-11-02
  • ## utf8_unicode_ci 與 utf8_bin:哪一種 MySQL 排序規則最適合德國網站?
    ## utf8_unicode_ci 與 utf8_bin:哪一種 MySQL 排序規則最適合德國網站?
    為德語選擇最佳MySQL 排序規則為德語選擇最佳MySQL 排序規則在設計為德語受眾量身定制的網站時,支持像ä、 ü 和ß。當涉及特定於語言的要求時,排序規則的選擇起著重要作用。 字元集和排序規則對於字元處理,UTF-8 仍然是首選選項,提供廣泛的字元支援。至於排序規則,則需要考慮德語特定字元。 排...
    程式設計 發佈於2024-11-02
  • 異常處理基礎知識
    異常處理基礎知識
    Java中的例外處理由五個關鍵字管理:try、catch、 throw、throws和finally。 這些關鍵字構成了一個相互關聯的子系統。 要監視的指令位於 try 區塊內。 如果try區塊中發生異常,則會拋出異常。 程式碼可以使用catch捕獲並處理異常。 系統異常由Java執行時...
    程式設計 發佈於2024-11-02
  • 好的第一期:做出您的第一個開源貢獻
    好的第一期:做出您的第一個開源貢獻
    嘿,未來的開源貢獻者! ? 一開始為開源做出貢獻可能會令人生畏,尤其是當專案有數千行程式碼並且對問題進行深入討論時。但這就是為什麼好的首要問題存在。它們就像是一個友好的邀請,讓你嘗試並熟悉操作,而不會迷失在雜草中。將它們視為幫助您開始騎乘的輔助輪。 無論如何,什麼是好的第一期? ...
    程式設計 發佈於2024-11-02
  • 目錄:Django 基礎知識
    目錄:Django 基礎知識
    點此收聽我的直播 目錄:Django 基礎 Django簡介 Django框架概述 安裝Python 設定虛擬環境 安裝 Django 創建您的第一個 Django 專案 Django 專案架構 瞭解 Django 的專案佈局 管理 Django 設定 配置資料庫設定 urls.py、views....
    程式設計 發佈於2024-11-02

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3