默认导出 vs 具名导出

一个文件里有且仅有一个 默认 导出,但是可以有任意多个 具名 导出。 组件的导出方式决定了其导入方式。当你用默认导入的方式,导入具名导出的组件时,就会报错。如下表格可以帮你更好地理解它们:

语法 导出语句 导入语句
默认 export default function Button() {} import Button from './Button.js';
具名 export function Button() {} import { Button } from './Button.js';

当使用默认导入时,你可以在 import 语句后面进行任意命名。比如 import Banana from './Button.js',如此你能获得与默认导出一致的内容。相反,对于具名导入,导入和导出的名字必须一致。这也是称其为 具名 导入的原因!

通常,文件中仅包含一个组件时,人们会选择默认导出,而当文件中包含多个组件或某个值需要导出时,则会选择具名导出。 无论选择哪种方式,请记得给你的组件和相应的文件命名一个有意义的名字。我们不建议创建未命名的组件,比如 export default () => {},因为这样会使得调试变得异常困难。

相关推荐
Jacky-0081 天前
Node + vite + React 创建项目
前端·react.js·前端框架
用户47949283569151 天前
为什么我的react项目启动后,dom上的类名里没有代码位置信息
前端·react.js
Jonathan Star1 天前
在 React 生态中,有多个成熟的 虚拟列表 npm 库
react.js·arcgis·npm
Dontla1 天前
前端状态管理,为什么要状态管理?(React状态管理、zustand)
前端·react.js·前端框架
宋辰月1 天前
学习react第一天
javascript·学习·react.js
骑自行车的码农2 天前
React SSR 技术实现原理
算法·react.js
Cxiaomu3 天前
React Native App 自动检测版本更新完整实现指南
javascript·react native·react.js
小p3 天前
react学习6:受控组件
前端·react.js
sophie旭3 天前
一个偶现bug引发的onKeyDown 和 onChange之战
前端·javascript·react.js
光影少年3 天前
React Native第六章
javascript·react native·react.js