ES6 模块导出 export default 与 export 的区别?

在 JavaScript(包括 React 组件)中,export default function Profile() {}export function Profile() {} 是两种不同的导出方式,核心区别在于导出类型导入方式,具体如下:

1. 导出类型不同

  • export default function Profile() {} :这是「默认导出(default export)」。一个模块(文件)中只能有一个默认导出 ,可以理解为 "模块的主要导出内容"。默认导出时,函数名(Profile)是可选的(可以写成匿名函数 export default function() {}),因为导入时可以自定义名称。
  • export function Profile() {} :这是「命名导出(named export)」。一个模块中可以有多个命名导出 ,每个导出都有明确的名称(这里是 Profile),必须通过名称来导入。

2. 导入方式不同

这是两者最直观的区别,导入时的语法完全不同:

(1)默认导出的导入方式:

可以自定义导入名称 (无需与导出时的名称一致),且不需要用大括号 {} 包裹。

js 复制代码
// 导出(默认导出)
export default function Profile() {}

// 导入(可自定义名称,比如 MyProfile)
import MyProfile from './Profile'; 

(2)命名导出的导入方式:

必须使用与导出时完全一致的名称 ,且必须用大括号 {} 包裹(称为 "解构导入")。

js 复制代码
// 导出(命名导出)
export function Profile() {}

// 导入(必须用 { Profile },名称必须一致)
import { Profile } from './Profile'; 

如果想自定义名称,需要用 as 关键字重命名:

js 复制代码
import { Profile as MyProfile } from './Profile'; 

3. 其他区别

  • 多个导出的支持

    • 默认导出:一个文件只能有 1 个 默认导出。

    • 命名导出:一个文件可以有 多个 命名导出,例如:

      js 复制代码
      // 多个命名导出
      export function Profile() {}
      export function Settings() {}
      export const version = '1.0';

      导入时可以按需导入:

      js 复制代码
      import { Profile, Settings } from './components';
  • 混合使用:一个模块可以同时包含「一个默认导出」和「多个命名导出」,例如:

    js 复制代码
    // 默认导出(1个)
    export default function Profile() {}
    
    // 命名导出(多个)
    export function Settings() {}
    export const version = '1.0';

    导入时需分别处理:

    js 复制代码
    import Profile, { Settings, version } from './components';

总结表格

特性 export default function Profile() {}(默认导出) export function Profile() {}(命名导出)
模块中数量限制 只能有 1 个 可以有多个
导出时名称 可选(可匿名) 必须有明确名称
导入时语法 import 自定义名称 from '路径' import { 原名称 } from '路径'
导入时名称灵活性 可自定义名称 必须与导出名称一致(可通过 as 重命名)

实际使用场景

  • 默认导出 :通常用于模块的 "主内容",比如一个组件文件的核心组件(如 Profile.js 中默认导出 Profile 组件),导入时更简洁。
  • 命名导出 :通常用于导出多个相关的工具函数、组件或常量(如一个 utils.js 文件导出多个工具函数),导入时可以按需选择,避免引入不必要的内容。
相关推荐
niucloud-admin4 小时前
web 端前端
前端
胖者是谁7 小时前
EasyPlayerPro的使用方法
前端·javascript·css
EndingCoder8 小时前
索引类型和 keyof 操作符
linux·运维·前端·javascript·ubuntu·typescript
liux35288 小时前
Web集群管理实战指南:从架构到运维
运维·前端·架构
沛沛老爹8 小时前
Web转AI架构篇 Agent Skills vs MCP:工具箱与标准接口的本质区别
java·开发语言·前端·人工智能·架构·企业开发
小光学长8 小时前
基于Web的长江游轮公共服务系统j225o57w(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
前端·数据库
Joe55610 小时前
vue2 + antDesign 下拉框限制只能选择2个
服务器·前端·javascript
ChangYan.10 小时前
monorepo 多包管理识别不到新增模块,解决办法
前端·chrome
Jinuss10 小时前
React元素创建介绍
前端·react.js
济61710 小时前
linux 系统移植(第六期)--Uboot移植(5)--bootcmd 和 bootargs 环境变量-- Ubuntu20.04
java·前端·javascript