【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 更方便
相关推荐
绝无仅有11 分钟前
大厂面试相关文章:深入技术面试中的核心知识点
后端·面试·架构
绝无仅有14 分钟前
面试文章:网络协议与redis安全,https协议,TCP三次握手,四次挥手等面试经典问题
后端·面试·架构
涤生啊26 分钟前
一键搭建 Coze 智能体对话页面:支持流式输出 + 图片直显,开发效率拉满!
javascript·html5
吃饺子不吃馅42 分钟前
⚡️ Zustand 撤销重做利器:Zundo 实现原理深度解析
前端·javascript·github
远航_2 小时前
10 个被严重低估的 JS 特性,直接少写 500 行代码
前端·javascript
小高0072 小时前
当前端面临百万级 API 请求:从"修 CSS 的"到架构师的进化之路
前端·javascript·面试
LateFrames2 小时前
使用 Winform / WPF / WinUI3 / Electron 实现异型透明窗口
javascript·electron·wpf·winform·winui3
前端老宋Running2 小时前
为什么react~Hooks只能在组件最顶层调用
前端·react.js·面试
Asort2 小时前
React类组件精要:定义机制与生命周期方法进阶教程
前端·javascript·react.js
陳陈陳2 小时前
从“变量提升”到“调用栈爆炸”:V8 引擎是如何偷偷执行你的 JavaScript 的?
javascript