javascript技巧

关注公众号 jb51net

关闭
首页 > 网络编程 > JavaScript > javascript技巧 > ES6模块导出export default与export

ES6模块导出export default与export的区别示例详解

作者:晚夏_八月

ES6中在JavaScript ES6中export与export default均可用于导出常量、函数、文件、模块等,这篇文章主要介绍了ES6模块导出export default与export区别的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下

前言

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

1. 导出类型不同

2. 导入方式不同

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

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

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

// 导出(默认导出)
export default function Profile() {}

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

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

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

// 导出(命名导出)
export function Profile() {}

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

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

import { Profile as MyProfile } from './Profile'; 

3. 其他区别

总结表格

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

实际使用场景

到此这篇关于ES6模块导出export default与export区别的文章就介绍到这了,更多相关ES6模块导出export default与export内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文