”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 了解 JavaScript 中的导出和导入

了解 JavaScript 中的导出和导入

发布于2024-11-09
浏览:462

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]删除
最新教程 更多>
  • 如何修复 macOS 上 Django 中的“配置不正确:加载 MySQLdb 模块时出错”?
    如何修复 macOS 上 Django 中的“配置不正确:加载 MySQLdb 模块时出错”?
    MySQL配置不正确:相对路径的问题在Django中运行python manage.py runserver时,可能会遇到以下错误:ImproperlyConfigured: Error loading MySQLdb module: dlopen(/Library/Python/2.7/site-...
    编程 发布于2024-11-09
  • 大批
    大批
    方法是可以在对象上调用的 fns 数组是对象,因此它们在 JS 中也有方法。 slice(begin):将数组的一部分提取到新数组中,而不改变原始数组。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index p...
    编程 发布于2024-11-09
  • 如何增加 PHP 最大 POST 变量限制?
    如何增加 PHP 最大 POST 变量限制?
    PHP最大POST变量限制处理具有大量输入字段的POST请求时,当变量数量超过默认值时,会出现常见问题PHP 中的限制。例如,超过 1000 个字段的表单可能只公开 $_POST 数组中的前 1001 个变量。要解决此问题,需要调整 PHP 允许的 POST 变量的最大数量。在版本 5.3.9 中引...
    编程 发布于2024-11-09
  • 如何防止 Pandas 在保存 CSV 时添加索引列?
    如何防止 Pandas 在保存 CSV 时添加索引列?
    避免使用 Pandas 保存的 CSV 中的索引列使用 Pandas 进行修改后保存 csv 文件时,默认行为是包含索引列。为了避免这种情况,可以在使用 to_csv() 方法时将索引参数设置为 False。为了详细说明,请考虑以下命令序列:pd.read_csv('C:/Path/to/file....
    编程 发布于2024-11-09
  • 为什么 OpenX 仪表板显示“错误 330 (net::ERR_CONTENT_DECODING_FAILED)”?
    为什么 OpenX 仪表板显示“错误 330 (net::ERR_CONTENT_DECODING_FAILED)”?
    错误 330 (net::ERR_CONTENT_DECODING_FAILED):解开压缩问题遇到神秘的“错误 330 (net::ERR_CONTENT_DECODING_FAILED)” “在导航到仪表板页面时,必须深入研究根本原因。当 Web 服务器错误识别 HTTP 请求中使用的内容压缩方...
    编程 发布于2024-11-09
  • 除了“if”语句之外:还有哪些地方可以在不进行强制转换的情况下使用具有显式“bool”转换的类型?
    除了“if”语句之外:还有哪些地方可以在不进行强制转换的情况下使用具有显式“bool”转换的类型?
    无需强制转换即可上下文转换为 bool您的类定义了对 bool 的显式转换,使您能够在条件语句中直接使用其实例“t”。然而,这种显式转换提出了一个问题:“t”在哪里可以在不进行强制转换的情况下用作 bool?上下文转换场景C 标准指定了四种值可以根据上下文转换为的主要场景bool:语句:if、whi...
    编程 发布于2024-11-09
  • 如何在Java中使用堆栈将算术表达式解析为树结构?
    如何在Java中使用堆栈将算术表达式解析为树结构?
    在 Java 中将算术表达式解析为树结构从算术表达式创建自定义树可能是一项具有挑战性的任务,特别是在确保树结构时准确反映表达式的操作和优先级。要实现这一点,一种有效的方法是使用堆栈。以下是该过程的逐步描述:初始化:从空堆栈开始。处理令牌:迭代表达式中的每个标记:如果标记是左括号,则压入它如果 tok...
    编程 发布于2024-11-09
  • 在 Go 中使用 WebSocket 进行实时通信
    在 Go 中使用 WebSocket 进行实时通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    编程 发布于2024-11-09
  • 如何进行有替换和无替换的有效加权随机选择?
    如何进行有替换和无替换的有效加权随机选择?
    带替换和不带替换的加权随机选择为了应对编程挑战,我们寻求从列表中进行加权随机选择的有效算法, 带替换的加权选择一种有效的方法带替换的加权选择是别名方法。该技术为每个加权元素创建一组相同大小的箱。通过利用位操作,我们可以有效地索引这些容器,而无需诉诸二分搜索。每个 bin 存储一个百分比,表示原始加权...
    编程 发布于2024-11-09
  • 如何在不依赖框架的情况下确定 DOM 准备情况?
    如何在不依赖框架的情况下确定 DOM 准备情况?
    Document.isReady:DOM 就绪检测的本机解决方案依赖于 Prototype 和 jQuery 等框架来管理 window.onload 事件可能不会总是令人向往。本文探讨了确定 DOM 就绪情况的替代方法,特别是通过使用 document.isReady.查询 Document.is...
    编程 发布于2024-11-09
  • 如何在 Golang 中检索 XML 数组中的所有元素而不仅限于第一个元素?
    如何在 Golang 中检索 XML 数组中的所有元素而不仅限于第一个元素?
    在 XML 中解组数组元素:检索所有元素,而不仅仅是第一个当使用 xml.Unmarshal( 在 Golang 中解组 XML 数组时[]byte(p.Val.Inner), &t),您可能会遇到仅检索第一个元素的情况。要解决此问题,请利用 xml.Decoder 并重复调用其 Decode 方法...
    编程 发布于2024-11-09
  • 带有管理面板的轻量级 Rest Api,可轻松管理食物食谱。
    带有管理面板的轻量级 Rest Api,可轻松管理食物食谱。
    你好, ?所有这篇文章都是关于我刚刚在 Github 上发布的 Django Rest Framework API。 如果您正在寻找一些简单而高效的 API 来从管理面板管理食物食谱并将其返回以供客户端使用,那么此存储库适合您。 该代码是轻量级的,可以在任何低功耗迷你 PC(如 Raspberry...
    编程 发布于2024-11-09
  • 如何使用正则表达式匹配带有或不带有可选 HTTP 和 WWW 前缀的 URL?
    如何使用正则表达式匹配带有或不带有可选 HTTP 和 WWW 前缀的 URL?
    使用可选 HTTP 和 WWW 前缀匹配 URL正则表达式是执行复杂模式匹配任务的强大工具。当涉及到匹配 URL 时,格式通常会有所不同,例如是否包含“http://www”。 使用正则表达式的解决方案匹配带或不带“http://www”的 URL。前缀,可以使用以下正则表达式:((https?|f...
    编程 发布于2024-11-09
  • 如何在不依赖扩展名的情况下确定文件类型?
    如何在不依赖扩展名的情况下确定文件类型?
    如何在不依赖扩展名的情况下检测文件类型除了检查文件的扩展名之外,确定文件是 mp3 还是图像格式是很有价值的编程中的任务。这是一个不依赖扩展的全面解决方案:PHP >= 5.3:$mimetype = finfo_fopen(fopen($filename, 'r'), FILEINFO_MIME_...
    编程 发布于2024-11-09
  • 在 JavaScript 中实现斐波那契数列:常见方法和变体
    在 JavaScript 中实现斐波那契数列:常见方法和变体
    作为开发人员,您可能遇到过编写函数来计算斐波那契数列中的值的任务。这个经典问题经常出现在编码面试中,通常要求递归实现。然而,面试官有时可能会要求具体的方法。在本文中,我们将探讨 JavaScript 中最常见的斐波那契数列实现。 什么是斐波那契数列? 首先,让我们回顾一下。斐波那契数...
    编程 发布于2024-11-09

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3