export 和 export default 的区别

export

export命令用于规定模块的对外接口。一个模块就是一个独立的文件。该文件内部的所有变量,外部无法获取。如果你希望外部能够读取模块内部的某个变量,就必须使用export关键字输出该变量。

// profile.js
export var firstName = 'Jack';
export var lastName = 'Ma';
export var year = 1964;
// profile.js
var firstName = 'Jack';
var lastName = 'Ma';
var year = 1964;
export {firstName, lastName, year};

应该优先考虑使用第2种写法。因为这样就可以在脚本尾部,一眼看清楚输出了哪些变量。export命令除了输出变量,还可以输出函数或类(class)。

import命令接受一对大括号,里面指定要从其他模块导入的变量名。大括号里面的变量名,必须与被导入模块(profile.js)对外接口的名称相同。如果想为输入的变量重新取一个名字,import命令要使用as关键字,将输入的变量重命名。

import { lastName as surname } from './profile.js';

export default

export default命令,为模块指定默认输出。使用import命令的时候,用户需要知道所要加载的变量名或函数名,否则无法加载。但是,用户肯定希望快速上手,未必愿意阅读文档,去了解模块有哪些属性和方法。为了给用户提供方便,让他们不用阅读文档就能加载模块,就要用到export default命令,为模块指定默认输出。

// export-default.js
export default function () {console.log('foo');
}

上面代码是一个模块文件export-default.js,它的默认输出是一个函数。

与export命令的区别:其他模块加载该模块时,import命令可以为该匿名函数指定任意名字。

// import-default.js
import customName from './export-default'; //默认输出的函数
customName(); // 'foo'

上面代码的import命令,可以用任意名称指向export-default.js输出的方法,这时就不需要知道原模块输出的函数名。需要注意的是,这时import命令后面,不使用大括号。

本质上,export default就是输出一个叫做default的变量或方法,然后系统允许你为它取任意名字。所以,下面的写法是有效的。

// modules.js
function add(x, y) {return x * y;
}
export {add as default};
// 等同于
// export default add;// app.js
import { default as foo } from 'modules';
// 等同于
// import foo from 'modules';

正是因为export default命令其实只是输出一个叫做default的变量,所以它后面不能跟变量声明语句。

**总结:**export命令对外接口是有名称的且import命令从模块导入的变量名与被导入模块对外接口的名称相同,而export default命令对外输出的变量名可以是任意的,这时import命令后面,不使用大括号。

export default命令用于指定模块的默认输出。显然,一个模块只能有一个默认输出,因此export default命令只能使用一次。所以,import命令后面才不用加大括号,因为只可能唯一对应export default命令。

react中export 和 export default相关推荐

  1. ES6中export及export default的区别

    在ES6中,export和export default均可用于导出常量.函数.文件.模块等,你可以在其他文件或模块中通过import + (常量 | 函数 | 文件 | 模块)名的方式将其导入,以便能 ...

  2. es6中export和export default的区别

    export与export default均可用于导出常量.函数.文件.模块你可以在其它文件或模块中通过import+(常量 | 函数 | 文件 | 模块)名的方式,将其导入,以便能够对其进行使用在一 ...

  3. Vue 中 export及export default的区别

    相信很多人都在vue使用过export.export default.import,然而它们到底有什么区别呢? 在ES6中,export与export default均可用于导出常量.函数.文件.模块 ...

  4. react 中使用import()实现按需加载报错 解决方法 --‘import’ and ‘export’ may only appear at the top level

    react 中使用import()实现按需加载报错 解决方法 --'import' and 'export' may only appear at the top level 参考文章: (1)rea ...

  5. Vue中的export和export default{}用法

    目录 一.export 的使用 二.export default 的使用 三.两者之间的区别 区别 1: 区别 2: 区别 3:  在JavaScript ES6中,export 与 export d ...

  6. vue中export和export default

    1.export和import的涵义 export主要用于对外输出本模块变量的接口,一个文件就可以被理解为一个模块.export就是导出. import就是在一个模块中加载另一个含有export接口的 ...

  7. Vue中export和export default的区别和用法

    Vue是通过webpack实现的模块化,因此可以使用import来引入模块,例如: import Vue from 'vue'   import Router from 'vue-router'   ...

  8. export和export default的区别

    es6中export和export default的区别 export与export default均可用于导出常量.函数.文件.模块: 你可以在其它文件或模块中通过import+(常量 | 函数 | ...

  9. export ,export default 和 import 区别 以及用法

    首先要知道export,import ,export default是什么 ES6模块主要有两个功能:export和import export用于对外输出本模块(一个文件可以理解为一个模块)变量的接口 ...

最新文章

  1. pygame加载MP3音乐
  2. 关于从 coding 拉项目的操作
  3. Python-读写文件
  4. [MySQL基础]数据库存储数据的特点
  5. 前端学习(120):css精灵和好处
  6. 解决克隆clone github 仓库速度过慢的问题
  7. 关于js中的判断数组为空的问题
  8. 【状压DP】poj2686 Traveling by Stagecoach
  9. python post 上传文件_python接口自动化7-post文件上传
  10. 五分钟快速过完Verilog HDL基本概念(1)
  11. C#之Application.DoEvents()
  12. easyui 图标下拉框
  13. 叮咚志汇超级外卖餐饮 6.3.8 + 超级跑腿 v2.0.3 打包下载 小程序模块
  14. CentOS7/rhel7 T440P 控制散热风扇转速等级
  15. 【实战技能】非技术背景经理的技术管理
  16. 大数据学习之路 JUC篇
  17. 解决JWT解析token数据时拿不到问题
  18. SpringSecurity: 不能混用authorizeRequests和6.0里的authorizeHttpReuests
  19. 跨平台桌面应用的开发框架——Electron
  20. C++ 无法打开 源 文件「bits/stdc++.h」//E1696

热门文章

  1. vue 实现简易卡包效果
  2. [php] 如何正确发布 PHP 代码
  3. CSS浮动、PS切图、学成在线案例前期准备
  4. android释放焦点_android 取消edittext焦点
  5. 用vulkan写个引擎 (三)ui组件
  6. PMP考试“临门一脚”如何踢得漂亮?
  7. Power Table(超强动态表格)
  8. python3中的call函数
  9. 暴力破解时常说的万能密码是什么
  10. Linux学习 -- Docker加速器配置