」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 了解 JavaScript 中的匯出和匯入

了解 JavaScript 中的匯出和匯入

發佈於2024-11-09
瀏覽:650

Understanding Exports and Imports in JavaScript

在 JavaScript 中,模組是獨立的程式碼單元,可以使用匯出將資產公開給其他模組,並使用導入使用來自其他模組的資產。這種機制對於在現代 JavaScript 應用程式中建立模組化和可重複使用的程式碼至關重要。

預設導出

  • 一個模組只能有一個預設導出。
  • 要匯出預設資源,請在匯出的實體之前使用 default 關鍵字。
  • 要匯入預設匯出,可以直接將其賦值給變量,而無需指定匯出名稱:
// Exporting a default asset
export default function greet(name) {
  console.log(`Hello, ${name}!`);
}

// Importing the default export
import greet from './myModule';

命名導出

  • 一個模組可以有多個命名導出。
  • 要匯出命名資源,請在匯出的實體之前使用匯出關鍵字並為其命名。
  • 要匯入命名匯出,您必須指定要匯入的資源的名稱:
// Exporting named assets
export function greet(name) {
  console.log(`Hello, ${name}!`);
}

export function farewell(name) {
  console.log(`Goodbye, ${name}!`);
}

// Importing named exports
import { greet, farewell } from './myModule';

合併預設導出和命名導出

您可以在單一模組中同時擁有預設導出和命名導出:

export default function greet(name) {
  console.log(`Hello, ${name}!`);
}

export function farewell(name) {
  console.log(`Goodbye, ${name}!`);
}

要匯入預設匯出和命名匯出:

import greet, { farewell } from './myModule';

要記住的要點

  • 導出用於公開模組中的資產。
  • import 用於消耗其他模組的資源。
  • 一個模組只能有一個預設導出。
  • 命名匯出可以單獨或集體匯入。
  • 用於匯入的名稱是任意的,不必與匯出模組中使用的名稱相符。

實際範例

考慮一個 React 元件:

import React from 'react';

export default function Greeting({ name }) {
  return 

Hello, {name}!

; }

在此範例中,Greeting 元件將作為預設導出進行匯出。可以匯入並在其他元件中使用:

import Greeting from './Greeting';

function MyComponent() {
  return ;
}

透過了解匯出和匯入,您可以有效地組織和重複使用 JavaScript 專案中的程式碼。

版本聲明 本文轉載於:https://dev.to/shieldstring/understanding-exports-and-imports-in-javascript-3gm?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 在 JavaScript 中實作斐波那契數列:常見方法和變體
    在 JavaScript 中實作斐波那契數列:常見方法和變體
    作為開發人員,您可能遇到過編寫函數來計算斐波那契數列中的值的任務。這個經典問題經常出現在程式設計面試中,通常要求遞歸實現。然而,面試官有時可能會要求具體的方法。在本文中,我們將探討 JavaScript 中最常見的斐波那契數列實作。 什麼是斐波那契數列? 首先,讓我們回顧一下。斐波...
    程式設計 發佈於2024-11-09
  • 如何使用 .htaccess 更改共享伺服器上的 PHP 版本?
    如何使用 .htaccess 更改共享伺服器上的 PHP 版本?
    在共享伺服器上透過.htaccess 更改PHP 版本如果您正在操作共享伺服器並且需要更改PHP 版本,可以透過.htaccess文件來做到這一點。這允許您為您的網站運行特定的 PHP 版本,同時伺服器維護其預設版本。 要切換 PHP 版本,請按照下列步驟操作:找到 . htaccess 檔案: 該...
    程式設計 發佈於2024-11-09
  • 如何在Ajax資料載入過程中顯示進度條?
    如何在Ajax資料載入過程中顯示進度條?
    如何在Ajax 資料載入期間顯示進度條處理使用者觸發的事件(例如從下拉方塊中選擇值)時,通常會使用非同步擷取資料阿賈克斯。在獲取數據時,向用戶提供正在發生某事的視覺指示是有益的。本文探討了一種在 Ajax 請求期間顯示進度條的方法。 使用 Ajax 實作進度條要建立一個準確追蹤 Ajax 呼叫進度的...
    程式設計 發佈於2024-11-09
  • TCJavaScript 更新、TypeScript Beta、Node.js 等等
    TCJavaScript 更新、TypeScript Beta、Node.js 等等
    歡迎來到新一期的「JavaScript 本週」! 今天,我們從 TC39、Deno 2 正式版本、TypeScript 5.7 Beta 等方面獲得了一些針對 JavaScript 語言的巨大新更新,所以讓我們開始吧! TC39 更新:JavaScript 有何變化? 最近在東京...
    程式設計 發佈於2024-11-09
  • 為什麼 Bootstrap 用戶應該在下一個專案中考慮使用 Tailwind CSS?
    為什麼 Bootstrap 用戶應該在下一個專案中考慮使用 Tailwind CSS?
    Tailwind CSS 入门 Bootstrap 用户指南 大家好! ?如果您是 Bootstrap 的长期用户,并且对过渡到 Tailwind CSS 感到好奇,那么本指南适合您。 Tailwind 是一个实用程序优先的 CSS 框架,与 Bootstrap 基于组件的结构相比...
    程式設計 發佈於2024-11-09
  • 組合與繼承
    組合與繼承
    介绍 继承和组合是面向对象编程(OOP)中的两个基本概念,但它们的用法不同并且具有不同的目的。这篇文章的目的是回顾这些目的,以及选择它们时要记住的一些事情。 继承的概念 当我们考虑在设计中应用继承时,我们必须了解: 定义:在继承中,一个类(称为派生类或子类)可以从另...
    程式設計 發佈於2024-11-09
  • 如何在 JavaScript 中將浮點數轉換為整數?
    如何在 JavaScript 中將浮點數轉換為整數?
    如何在 JavaScript 中將浮點數轉換為整數要將浮點數轉換為整數,您可以使用 JavaScript內建數學物件。 Math 物件提供了多種處理數學運算的方法,包括舍入和截斷。 方法:1。截斷:截斷去除數字的小數部分。要截斷浮點數,請使用 Math.floor()。此方法向下舍入到小於或等於原始...
    程式設計 發佈於2024-11-09
  • 標準字串實作中的 c_str() 和 data() 是否有顯著差異?
    標準字串實作中的 c_str() 和 data() 是否有顯著差異?
    標準字串實作中的c_str()與data()STL中c_str()和data()函數的區別人們普遍認為類似的實作是基於空終止的。據推測,c_str() 總是提供以 null 結尾的字串,而 data() 則不然。 然而,在實踐中,實作經常透過讓 data() 在內部呼叫 c_str() 來消除這種區...
    程式設計 發佈於2024-11-09
  • C/C++ 中的類型轉換如何運作以及程式設計師應該注意哪些陷阱?
    C/C++ 中的類型轉換如何運作以及程式設計師應該注意哪些陷阱?
    了解C/C 中的類型轉換型別轉換是C 和C 程式設計的一個重要方面,涉及將資料從一種類型轉換為另一種類型。它在記憶體管理、資料操作和不同類型之間的互通性方面發揮著重要作用。然而,了解類型轉換的工作原理及其限制對於防止潛在錯誤至關重要。 明確型別轉換使用 (type) 語法執行的明確型別轉換可讓程式設...
    程式設計 發佈於2024-11-09
  • 我們如何在 Golang 中為不同的資料類型建立通用函數?
    我們如何在 Golang 中為不同的資料類型建立通用函數?
    Golang 中的通用方法參數在 Go 中,一個常見的需求是有一個對不同類型的資料進行操作的函數。以計算特定類型切片中元素數量的函數為例。如何設計這個函數來處理任何類型的數據,而不僅僅是它最初設計的特定類型? 一種方法是使用接口,它本質上是定義類型必須的一組方法的契約實現以符合接口。透過使用介面作為...
    程式設計 發佈於2024-11-09
  • 使用 Node.js 流進行高效能資料處理
    使用 Node.js 流進行高效能資料處理
    在本文中,我们将深入研究 Node.js Streams 并了解它们如何帮助高效处理大量数据。流提供了一种处理大型数据集的优雅方式,例如读取大型文件、通过网络传输数据或处理实时信息。与一次性读取或写入整个数据的传统 I/O 操作不同,流将数据分解为可管理的块并逐块处理它们,从而实现高效的内存使用。 ...
    程式設計 發佈於2024-11-09
  • 如何在 Python 中產生字串的所有可能排列,包括處理重複項?
    如何在 Python 中產生字串的所有可能排列,包括處理重複項?
    Python 中的字串排列查找給定字串的所有可能排列可能是一項具有挑戰性的任務。然而,Python使用itertools模組提供了一個簡單的解決方案。 解決方案:itertools.permutations()itertools.permutations()方法是專門為生成排列而設計的。它接受一個可...
    程式設計 發佈於2024-11-09
  • 如何不使用CMD直接從C++呼叫Java函數?
    如何不使用CMD直接從C++呼叫Java函數?
    從C 應用程式呼叫Java 函數從C 應用程式呼叫Java 函數是一項挑戰,特別是在尋求繞過使用的直接解決方案時要在這兩種語言之間建立通信,請考慮「從C 建立JVM」中詳細介紹的方法。它概述了創建 JVM 並隨後呼叫 Java 方法的過程。 在 JVM 已經存在的情況下(例如,當 Java 程式呼叫...
    程式設計 發佈於2024-11-09
  • 為什麼我無法更改 IE8 中禁用的 HTML 控制項的文字顏色?
    為什麼我無法更改 IE8 中禁用的 HTML 控制項的文字顏色?
    IE8 中禁用的HTML 控制項的CSS 顏色變更問題在HTML 中,disabled 屬性停用輸入控制項,但它也會影響控制項這些控制項的外觀。大多數瀏覽器都支援使用 CSS 套用於停用控制項的自訂樣式。然而,Internet Explorer 8 (IE8) 在更改停用控制項的顏色方面提出了獨特的...
    程式設計 發佈於2024-11-09
  • DRUGHUB 的軟體需求規格 (SRS)
    DRUGHUB 的軟體需求規格 (SRS)
    1.介紹 1.1 目的 本文檔概述了 DRUGHUB 網站的軟體要求,該網站旨在促進沙烏地阿拉伯和埃及的藥品、醫療設備和必需品的採購、物流和供應鏈管理。該網站將透過簡化營運並確保無縫存取關鍵資源來為醫療保健組織提供服務。 1.2 範圍 DRUGHU...
    程式設計 發佈於2024-11-09

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

Copyright© 2022 湘ICP备2022001581号-3