详解import导入和export和export default导出的区别

        在项目中,我们经常会看到使用 import xx  from 'xxx'; 或者 import {xx}  from 'xxx'; 进行模块的导入,那对于在导入模块的时候什么情况下添加花括号 {} 什么情况下直接导入,这两种写法的区别又是什么呢?今天这篇文章主要解决关于模块导入导出的各种疑惑和疑难杂症。

一、背景

        在ES6之前,社区制定的模块加载方案主要有 CommonJS 和 AMD 两种。前者用于服务器,后者用于浏览器。

        ES6在语言标准的层面上,实现了模块功能,完全可以取代 CommonJS 和 AMD 规范,成为浏览器和服务器通用的模块解决方案。

二、import、export和export default的应用场景

        模块是一种封装了特定功能的代码的单元。一个模块就是一个独立的文件。该文件内部的所有变量,外部无法获取。若要实现外部能够读取模块内部的某个变量,就必须使用export/export default 关键字输出该变量。

        在JavaScript ES6中,export与export default均可用于导出常量、函数、文件、模块等。

        import用于在一个文件中倒入另一个文件中用export或者export default导出的模块。

三、区别

1、export与export default均可用于导出常量、函数、文件、模块等;

2、在一个文件或者模块中,export、import可以有多个,export default仅有一个(但是一个export default可以借助{}在该文件中导出多个默认子模块);

3、通过export方式导出,在import导入时要加{},export default在导入时不需要,并可以任意起名称。

4、通过export default导出一个模块中的多个子模块时,在用import 导入后,需要使用导出时的某个子模块的话,需要用import导入时的变量点.出来,即若用import导出export default时的模块命名为a,需要用到导出的a中的b,则使用时需要用a.b来调用b变量。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值