」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > React 模組化簡介:AMD 與 CommonJS 模組化

React 模組化簡介:AMD 與 CommonJS 模組化

發佈於2024-11-11
瀏覽:248

Uvod u Modularizaciju u React-u: AMD i CommonJS modularizacija

模块化是现代应用程序开发的核心,尤其是在使用像 React 这样的库时。了解模块化和不同的模块化方法(例如 AMD 和 CommonJS)是开发高效、可维护和可扩展代码的关键。在这篇博文中,我们将探讨模块化在 React 应用程序中的工作原理、为什么它很重要,以及 AMD 和 CommonJS 的模块化方法如何提高 JavaScript 应用程序的效率。

为什么模块化是 React 应用程序的关键?

使用 React 时,模块化使我们能够将用户界面分解为更小的部分(组件),这些部分作为独立的单元运行。本质上,每个组件代表用户界面的一部分,具有自己的样式、功能和依赖关系,这使得应用程序更加透明,并有利于其开发和维护。

模块化还有助于降低不同代码之间发生冲突的风险,因为每个组件都可以使用自己的模块和资源独立运行。这让我们认识到 React 应用程序中模块化的重要性:每个组件都可以定义为单独的模块,这简化了依赖管理并允许团队合作顺利运行而不会分心。

React 中的模块结构

React 应用程序通常遵循对相关组件和资源进行分组的文件夹结构。假设我们正在构建一个简单的应用程序,其中包含“主页”、“关于”和“联系方式”等几个页面。我们可以将它们模块化,以便每个文件代表一个组件,而不是在一个文件中定义所有页面。下面是它的示例:

// Home.js
export default function Home() {
  return 

Home Page

; } // About.js export default function About() { return

About Page

; } // Contact.js export default function Contact() { return

Contact Page

; }

当应用程序的每个部分被划分为独立的模块(组件)时,我们可以轻松地在应用程序的其他部分中重用这些部分。这种方法有助于保持应用程序整洁、易于维护和可扩展。

JavaScript 中的 AMD 和 CommonJS 模块化

虽然 ES6 模块是现代 JavaScript 中的标准,并且经常在 React 应用程序中使用,但 JavaScript 世界中还有其他流行的标准,例如 AMD(异步模块定义) CommonJS 。尽管它们在 React 应用程序中并不同样常见,但了解它们之间的差异有助于处理不同的 JavaScript 项目,尤其是那些不依赖 React 的项目。

CommonJS

CommonJS 是为服务器端 JavaScript 环境(尤其是 Node.js)开发的模块化。该标准使用 module.exports 导出模块并要求加载它们。 CommonJS 的一个关键特性是同步性,这意味着模块按顺序加载,适用于服务器端环境,在服务器端环境中,同步(按顺序)加载模块通常更高效且更符合服务器需求。

CommonJS模块化示例:

// math.js
module.exports = {
  add: (a, b) => a   b,
  subtract: (a, b) => a - b,
};

// main.js
const math = require('./math');
console.log(math.add(2, 3)); // 5

在 CommonJS 中,我们使用 module.exports 定义模块所需的一切。当我们想要使用一个模块时,我们只需需要它。由于这种简单性,CommonJS 成为 Node.js 项目最常见的标准,并允许开发人员通过 Node Package Manager (NPM) 共享模块。

AMD(异步模块定义)

与 CommonJS 不同,AMD(异步模块定义)标准主要用于浏览器应用程序。它旨在启用异步模块加载,这对于优化浏览器性能至关重要。

采用异步加载,模块不是按顺序加载,而是并行下载,减少等待时间,实现更快的页面加载。 AMD使用define函数来定义模块,并使用require函数来加载它们。

AMD模块化示例:

// math.js
define([], function () {
  return {
    add: function (a, b) {
      return a   b;
    },
    subtract: function (a, b) {
      return a - b;
    },
  };
});

// main.js
require(['math'], function (math) {
  console.log(math.add(2, 3)); // 5
});

AMD 以一种非常适合性能和页面加载速度至关重要的环境的方式实现模块化。考虑到异步可以更有效地利用浏览器资源,AMD 在需要快速加载和交互性的大型 JavaScript 应用程序中很受欢迎。

CommonJS 和 AMD 模块化之间的主要区别是什么?

  1. 应用程序:CommonJS 非常适合服务器端 JavaScript 应用程序(例如 Node.js),而 AMD 专为异步可以提高性能的浏览器内应用程序而设计。

  2. 同步:CommonJS模块是同步加载的,意味着每个模块依次加载。另一方面,AMD 使用异步加载,允许浏览器内应用程序加载速度更快并更有效地使用资源。

  3. 复杂性:CommonJS 使用 require 加载模块,使用 module.exports 导出,非常简单。 AMD使用define来定义和require加载模块,这可能需要更多代码,但在浏览器中提供了更大的灵活性。

  4. 兼容性:CommonJS 在 Node.js 环境中运行良好,而 AMD 由于异步加载,在浏览器中提供了更大的灵活性。这使得它们适合不同的目的。

React 中的 AMD 和 CommonJS

在 React 中,AMD 和 CommonJS 并不经常使用,因为 ES6 模块(导入和导出)已经成为模块化的标准方式。但是,在处理不依赖 React 的项目(例如一些旧版 JavaScript 应用程序或基于 Node.js 的项目)时,熟悉 AMD 和 CommonJS 模块可能会很有用。

结论

代码模块化可以构建可扩展、有组织且高效的应用程序。尽管 ES6 模块主要用于 React,但在使用不同的 JavaScript 项目和工具时,了解 AMD 和 CommonJS 模块化会很有用。 CommonJS 由于其同步加载而非常适合服务器端应用程序,而 AMD 可以在浏览器中更快地加载模块,使其成为浏览器应用程序的绝佳选择。

无论选择哪种方法,模块化都是现代 JavaScript 编程的基本实践,并为应用程序的组织、维护和性能带来了许多改进。

版本聲明 本文轉載於:https://dev.to/jelena_petkovic/uvod-u-modularizaciju-u-react-u-amd-i-commonjs-modularizacija-28h3?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 在 Go 中使用 WebSocket 進行即時通信
    在 Go 中使用 WebSocket 進行即時通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    程式設計 發佈於2024-11-14
  • 如何使用命令式方法更新 React 中的巢狀狀態?
    如何使用命令式方法更新 React 中的巢狀狀態?
    更新嵌套狀態的命令式方法在 React 中,狀態更新是不可變的。這意味著要更新嵌套物件或數組,您不能簡單地修改其屬性並期望變更反映在 UI 中。相反,您需要建立包含更新值的新物件或數組,然後將其傳遞給 setState。 考慮以下範例,其中我們要更新物件中索引 1 處的物件的 name 屬性儲存在狀...
    程式設計 發佈於2024-11-14
  • 原子變數有哪些不同的記憶體排序模型?
    原子變數有哪些不同的記憶體排序模型?
    瞭解記憶體排序的意思原子變數提供安全的記憶體存取和跨執行緒同步。了解不同的記憶體順序對於有效利用它們至關重要。 輕鬆:無記憶體同步。 可能重新排序的最佳化操作讀取和寫入。 順序一致 (seq_cst):最嚴格的排序。 防止對周圍的任何記憶體操作進行重新排序原子操作。 確保所有執行緒的記憶體存取一致。...
    程式設計 發佈於2024-11-14
  • 為什麼在 For 迴圈中放錯 Return 語句會影響輸入迴圈?
    為什麼在 For 迴圈中放錯 Return 語句會影響輸入迴圈?
    For循環中返回語句錯位在你的作業中,你遇到了一個問題,程式只允許輸入一隻寵物,儘管瞄準三個。這個問題源自於 make_list 函數中 return 語句的定位。 在 for 迴圈中,return 語句在到達函數時立即終止函數的執行。在提供的程式碼中,return 語句放置在循環內部,導致函數在第...
    程式設計 發佈於2024-11-14
  • 大批
    大批
    方法是可以在物件上呼叫的 fns 數組是對象,因此它們在 JS 中也有方法。 slice(begin):將陣列的一部分提取到新數組中,而不改變原始數組。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index ...
    程式設計 發佈於2024-11-14
  • 如何防止使用者關閉 Bootstrap 模式?
    如何防止使用者關閉 Bootstrap 模式?
    停用使用者啟動的 Bootstrap 模態退出您可以透過點選 Bootstrap 模態區域外部來阻止使用者關閉 Bootstrap 模態。這在您想要強制使用者在繼續操作之前與特定模態內容互動的情況下非常有用。 停用模態背景點擊關閉預設情況下,使用者可以透過點選模式視窗之外的任何位置來關閉模式。若要停...
    程式設計 發佈於2024-11-14
  • 如何在 Python 中將巢狀清單匯出到 CSV 檔案?
    如何在 Python 中將巢狀清單匯出到 CSV 檔案?
    在Python中將嵌套列表匯出到CSV檔案將嵌套列表(其中每個內部列表包含不同類型的元素)寫入CSV檔案可以在Python 中處理資料時這是一項常見任務。以下是應對這項挑戰的方法:Python 的 csv 模組提供了處理 CSV 作業的便利方法。若要將清單的清單(例如a = [[1.2,'a...
    程式設計 發佈於2024-11-14
  • 如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    在 PHP 中組合關聯數組在 PHP 中,將兩個關聯數組組合成一個數組是常見任務。考慮以下請求:問題描述:提供的代碼定義了兩個關聯數組,$array1和$array2。目標是建立一個新陣列 $array3,它合併兩個陣列中的所有鍵值對。 此外,提供的陣列具有唯一的 ID,而名稱可能重疊。要求是建構一...
    程式設計 發佈於2024-11-14
  • 如何有效率地提取Go Slice的最後一個元素?
    如何有效率地提取Go Slice的最後一個元素?
    Go 提取切片最後一個元素的最佳方法在 Go 中使用切片時,有效操作元素至關重要。一個常見的任務是提取最後一個元素,這可以透過多種方法來實現。 現有解決方案的缺點使用切片提供的解決方案[len(slice)-1 :][0] 看起來很麻煩並且涉及不必要的複雜性。它會傳回一個僅包含最後一個元素的切片,然...
    程式設計 發佈於2024-11-14
  • 為什麼我的 JavaScript 事件在動態元素追加後沒有被觸發?
    為什麼我的 JavaScript 事件在動態元素追加後沒有被觸發?
    動態元素追加後 JavaScript 事件未觸發您遇到了向 DOM 追加新元素後 JavaScript 事件未觸發的問題。這是因為 jQuery 僅識別頁面載入期間最初執行時存在的元素。 要解決此問題,您需要使用事件委託來擷取動態元素中的事件。事件委託涉及擷取頁面載入期間已經存在的 DOM 中較高層...
    程式設計 發佈於2024-11-14
  • `unshift()` 是在 JavaScript 中將元素新增到陣列的最有效方法嗎?
    `unshift()` 是在 JavaScript 中將元素新增到陣列的最有效方法嗎?
    JavaScript 中的最佳數組前置將元素前置到數組的開頭是 JavaScript 中的常見要求。在這裡,我們探索一種比問題中建議的傳統方法更好的方法。 Unshift 方法:本機解決方案JavaScript 提供了一個名為 unshift 的內建方法有效地將元素新增至陣列的開頭。與涉及建立新陣列...
    程式設計 發佈於2024-11-14
  • 在 JavaScript 中透過建構函數定義方法是否會建立重複的函數副本?
    在 JavaScript 中透過建構函數定義方法是否會建立重複的函數副本?
    JavaScript 中透過原型與建構函數定義方法的效能影響在JavaScript 中,存在兩種建立具有公用函數的「類”的方法:使用原型或建構函數。方法 1 透過建構函式將函數指派給實例,而方法 2 利用原型在所有實例之間共用函數。 雖然方法 2 通常被認為更有效率,但剝奪實例的私有實例變數是一個顯...
    程式設計 發佈於2024-11-14
  • 如何使用 matcha.css 設定 HTML 樣式
    如何使用 matcha.css 設定 HTML 樣式
    Written by Emmanuel Odioko✏️ Matcha, a famous green tea, is known for its stress-reducing benefits. I wouldn't claim that this tea necessarily inspire...
    程式設計 發佈於2024-11-14
  • 如何在 PHP 中從物件數組中提取屬性列?
    如何在 PHP 中從物件數組中提取屬性列?
    從物件陣列中提取屬性列要從一行中的物件陣列中提取屬性列,我們可以使用PHP array_column()函數,在PHP 7.0 中引入。 $cats = Array( (object) ['id' => 15], (object) ['id' => 18], (o...
    程式設計 發佈於2024-11-14
  • 為什麼嘗試在 CSS 中創建淡出效果時我的幻燈片動畫不起作用?
    為什麼嘗試在 CSS 中創建淡出效果時我的幻燈片動畫不起作用?
    CSS3過渡:淡出效果當嘗試使用純CSS實現淡出效果時,可能會感到困惑為什麼幻燈片動畫行不通。原因如下:淡出效果的關鍵在於轉換不透明度屬性。 top屬性,用於幻燈片動畫,不會產生想要的效果。 使用CSS3 Transition的淡出效果下面是一個如何實現淡出效果的例子使用CSS3過渡的淡出效果:.h...
    程式設計 發佈於2024-11-14

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

Copyright© 2022 湘ICP备2022001581号-3