【JS】export default 🆚 export

语法都正确,但导出方式不同,导入方式也不同,尤其在React和懒加载中区别很大

🆚对比讲解

写法 类型 导入方式 用在 React.lazy?
export default function MyComponent() 默认导出 import MyComponent from './MyComponent' 可以直接用
export function MyComponent() 具名导出 import { MyComponent } from './MyComponent' 不能直接用 (除非包 .then()

导入时别名区别

导出类型 导入时能重命名吗? 示例
默认导出 ✅ 可以随便命名 import A from '...'
具名导出 ✅ 使用 as import { X as Y } from '...'

✅ 1. export default function MyComponent() { ... }

  • 这是默认导出
  • 每个模块只能有一个默认导出。
  • 用法简单,适合 React 组件默认输出。
js 复制代码
// MyComponent.js
export default function MyComponent() {
  return <div>你好</div>;
}

导入方式:

js 复制代码
import MyComponent from './MyComponent';

用于懒加载:

js 复制代码
const MyComponent = React.lazy(() => import('./MyComponent')); // ✅ 直接用

✅ 2. export function MyComponent() { ... }

  • 这是具名导出
  • 一个文件可以导出多个具名变量或函数。
  • 更灵活,但懒加载时要做额外处理。
js 复制代码
// MyComponent.js
export function MyComponent() {
  return <div>你好</div>;
}

导入方式:

js 复制代码
import { MyComponent } from './MyComponent';

如果你要懒加载这个具名导出组件,需要手动指定 default:

js 复制代码
const MyComponent = React.lazy(() =>
  import('./MyComponent').then(module => ({ default: module.MyComponent }))
); // ✅ 可以,但稍麻烦

什么时候用哪个?

场景 推荐用法
单个 React 组件一个文件 export default(更常见)
多个工具函数 / 多个组件一起导出 export { A, B }(具名导出)
想用 React.lazy 简化写法 export default 更方便
相关推荐
AI人工智能+电脑小能手19 小时前
【大白话说Java面试题】【Java基础篇】第20题:HashMap在计算index的时候,为什么要对数组长度做减1操作
java·开发语言·数据结构·后端·面试·哈希算法·hash-index
恶猫19 小时前
网页自动化模拟操作时,模拟真实按键触发事件【终级方案】
前端·javascript·自动化·vue·网页模拟
逻辑驱动的ken19 小时前
Java高频面试考点场景题17
开发语言·jvm·面试·求职招聘·春招
Fuly102420 小时前
java面试知识点复习
java·开发语言·面试
小程故事多_8020 小时前
[大模型面试系列] 破解 Agent 软故障困局,四层防御 + 可观测性,筑牢生产级稳健性防线
人工智能·面试·职场和发展·智能体
ZC跨境爬虫20 小时前
跟着 MDN 学 HTML day_2:(表单分组与高级输入控件实战)
前端·javascript·css·ui·html
嵌入式小企鹅20 小时前
嵌入式面试宝典
学习·面试·嵌入式·嵌入式工程师·高薪offer
千寻girling21 小时前
滑动窗口刷了快一个月(26天)了 , 还没有刷完. | 含(操作系统学什么的Java 后端)
java·开发语言·javascript·c++·人工智能·后端·python
一袋米扛几楼9821 小时前
【报错问题】彻底解决 TypeScript 报错 TS2769: No overload matches this call (JWT 篇)
linux·javascript·typescript
牧码岛21 小时前
Web前端之JavaScrip中的Array、Object、Map和Set详解
前端·javascript·web·web前端