默认导出 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 () => {},因为这样会使得调试变得异常困难。

相关推荐
AlkaidSTART10 小时前
TanStack Query 技术指南:异步状态管理核心实践
前端·react.js
ZHENGZJM11 小时前
JWT 鉴权体系:令牌生成与解析
react.js·go
我命由我1234512 小时前
React - 组件优化、children props 与 render props、错误边界
前端·javascript·react.js·前端框架·html·ecmascript·js
Z_Wonderful12 小时前
React react-app-env.d.ts是 TypeScript 的全局类型声明文件,它的作用
前端·react.js·typescript
cat10month12 小时前
react坑点记录
前端·javascript·react.js
kgduu12 小时前
react源码学习之reconcile
前端·学习·react.js
whuhewei12 小时前
React Fiber架构
前端·react.js·架构
英俊潇洒美少年12 小时前
通用构建优化(编译阶段)+ Vue 专属运行时优化 + React 专属运行时优化
前端·vue.js·react.js
英俊潇洒美少年12 小时前
Vue 和 React 的核心渲染机制 对比
前端·vue.js·react.js
qq_6285157613 小时前
Java实现pdf导出
java·vue.js·react.js·pdf