react中export 和 export default
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相关推荐
- ES6中export及export default的区别
在ES6中,export和export default均可用于导出常量.函数.文件.模块等,你可以在其他文件或模块中通过import + (常量 | 函数 | 文件 | 模块)名的方式将其导入,以便能 ...
- es6中export和export default的区别
export与export default均可用于导出常量.函数.文件.模块你可以在其它文件或模块中通过import+(常量 | 函数 | 文件 | 模块)名的方式,将其导入,以便能够对其进行使用在一 ...
- Vue 中 export及export default的区别
相信很多人都在vue使用过export.export default.import,然而它们到底有什么区别呢? 在ES6中,export与export default均可用于导出常量.函数.文件.模块 ...
- 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 ...
- Vue中的export和export default{}用法
目录 一.export 的使用 二.export default 的使用 三.两者之间的区别 区别 1: 区别 2: 区别 3: 在JavaScript ES6中,export 与 export d ...
- vue中export和export default
1.export和import的涵义 export主要用于对外输出本模块变量的接口,一个文件就可以被理解为一个模块.export就是导出. import就是在一个模块中加载另一个含有export接口的 ...
- Vue中export和export default的区别和用法
Vue是通过webpack实现的模块化,因此可以使用import来引入模块,例如: import Vue from 'vue' import Router from 'vue-router' ...
- export和export default的区别
es6中export和export default的区别 export与export default均可用于导出常量.函数.文件.模块: 你可以在其它文件或模块中通过import+(常量 | 函数 | ...
- export ,export default 和 import 区别 以及用法
首先要知道export,import ,export default是什么 ES6模块主要有两个功能:export和import export用于对外输出本模块(一个文件可以理解为一个模块)变量的接口 ...
最新文章
- pygame加载MP3音乐
- 关于从 coding 拉项目的操作
- Python-读写文件
- [MySQL基础]数据库存储数据的特点
- 前端学习(120):css精灵和好处
- 解决克隆clone github 仓库速度过慢的问题
- 关于js中的判断数组为空的问题
- 【状压DP】poj2686 Traveling by Stagecoach
- python post 上传文件_python接口自动化7-post文件上传
- 五分钟快速过完Verilog HDL基本概念(1)
- C#之Application.DoEvents()
- easyui 图标下拉框
- 叮咚志汇超级外卖餐饮 6.3.8 + 超级跑腿 v2.0.3 打包下载 小程序模块
- CentOS7/rhel7 T440P 控制散热风扇转速等级
- 【实战技能】非技术背景经理的技术管理
- 大数据学习之路 JUC篇
- 解决JWT解析token数据时拿不到问题
- SpringSecurity: 不能混用authorizeRequests和6.0里的authorizeHttpReuests
- 跨平台桌面应用的开发框架——Electron
- C++ 无法打开 源 文件「bits/stdc++.h」//E1696