import 和 export
1、export 命令
export 命令用于规定模块的对外接口。
一个模块就是一个独立的文件。该文件内部所有的变量,外部无法获取。要想外部能够读取模块内部的某个变量,就必须使用 export 关键字输出该变量。
语法:
export { name1, name2, …, nameN };
export { variable1 as name1, variable2 as name2, …, nameN };
export let name1, name2, …, nameN; // also var
export let name1 = …, name2 = …, …, nameN; // also var, const
export default expression;
export default function (…) { … } // also class, function*
export default function name1(…) { … } // also class, function*
export { name1 as default, … };
export * from …;
export { name1, name2, …, nameN } from …;
export { import1 as name1, import2 as name2, …, nameN } from …;
nameN ---> 导出的标识符(用来被其它脚本的 import 导入)
//aa.js export var firstName = "Muhan"
export var lastName = "Wu"
export var year = 2017
在 aa.js 文件中,保存了用户信息,es6 将其视为一个模块,用 export 命令对外输出 3 个变量。我们还可以用另外一种写法来实现
//aa.js var firstName = "Muhan"
var lastName = "Wu"
var year = 2017 export {firstName, lastName, year}
这种写法在 export 命令后面使用大括号指定所要输出的一组变量,应该被优先考虑,因为这样就可以在脚本尾部,一眼看清楚输出了哪些变量
export 命令除了输出变量,还可以输出函数或类(Class)
在 my-module.js 模块里,我们可以这样导出
// my-module.js
export function cube(x) {
return x*x*x
}
const foo = Math.PI + Math.SQRT2
export {foo}
在其它脚本,我们可以这样导入:
import {cube, foo} from './my-module.js'
console.log( cube(3) ) //
console.log( foo ) // 4.555806215962888
通常情况下,export 输出的变量就是本来的名字,但是可以使用 as 关键字来重命名
// my-module.js
function aa () {
console.log('My name is Kobe Bryant')
}
function bb () {
console.log('I am one of the best players in NBA history')
}
export {
aa as personName,
bb as selfIntro,
bb as selfEvaluation
上面代码使用 as 关键字,重命名了函数 aa 和 bb 的对外接口。重命名后,bb 可以用不同的名字输出两次
import {personName, selfIntro, selfEvaluation} from './my-module'
personName() // My name is Kobe Bryant
selfIntro() // I am one of the best players in NBA history
selfEvaluation() // I am one of the best players in NBA history
注意:
(1)、export 命令规定的对外接口,必须与模块内部的变量建立一一对应的关系
// 报错,SyntaxError
export 1 // 报错,SyntaxError
var m = 1
export m /* ================================= */ // 正确写法一
export var m = 1 // 正确写法二
var m = 1
export {m} // 正确写法三
var m = 1
export {m as num}
// 报错
function myFun () {
// ...
} export myFun // 正确写法一
export function myFun () {
// ...
} // 正确写法二
function myFun () {
// ...
} export {myFun}
(2)、export 命令可以出现在模块的任何位置,只要处于模块顶层就可以。如果处于块级作用域内,就会报错(同样适用于 import 命令)
function foo() {
export default 'bar' // SyntaxError
}
foo()
// Module build failed: SyntaxError: 'import' and 'export' may only appear at the top level
2、import 命令
import 用于从一个已经导出的外部模块或另一个脚本中导入函数,对象或原始类型
使用 export 命令定义了模块的对外接口以后,其它 js 文件就可以通过 import 命令加载这个模块
语法:
import defaultMember from "module-name";
import * as name from "module-name";
import { member } from "module-name";
import { member as alias } from "module-name";
import { member1 , member2 } from "module-name";
import { member1 , member2 as alias2 , [...] } from "module-name";
import defaultMember, { member [ , [...] ] } from "module-name";
import defaultMember, * as name from "module-name";
import "module-name";
defaultMember
将引用从模块默认导出的名称
module-name
要导入的模块的名称
name
是将引用导出成员的名称,指向导入模块的对象的名称
member,memberN
指定独立成员,将要导入的导出成员的名称
alias,aliasN
将引用命名导入的名称
// my-module.js var firstName = "Muhan",
lastName = "Wu",
year = 2017; export {firstName, lastName, year} // 引用模块
import {firstName, lastName, year} from './my-module' console.log('My name is '+firstName+lastName+ ', I am '+year+' years old!') // My name is MuhanWu, I am 2017 years old!
同 export 命令一样,如果想为输入的变量重新取一个名字,import 命令要使用 as 关键字,将输入的变量重命名
// my-module.js
var aa = "Kobe Bryant"
export {aa}
---------------------------------------------------------------
import {aa as name} from './my-module'
console.log('My name is '+ name) // My name is Kobe Bryant
注意:
(1)、import 命令具有提升效果,会提升到整个模块的头部,首先执行
// my-module.js
var aa = "Kobe Bryant"
export {aa}
------------------------------------------------------
console.log('My name is '+ aa) // My name is Kobe Bryant
import {aa } from './my-module'
上面的代码没有报错,因为 import 的执行早于 aa的调用
(2)、由于 import 是静态执行,所以不能使用表达式和变量,这些只有在运行时才能得到结果的语法结构
// 报错
import { 'f' + 'oo' } from 'my_module'; // 报错
let module = 'my_module';
import { foo } from module; // 报错
if (x === 1) {
import { foo } from 'module1';
} else {
import { foo } from 'module2';
}
(3)、如果多次重复执行同一句 import 语句,那么只会执行一次,不会执行多次
import { foo } from 'my_module';
import { bar } from 'my_module';
// 等同于
import { foo, bar } from 'my_module';
3、export default 命令
从前面的例子可以看出,使用import命令的时候,用户需要知道所要加载的变量名或函数名,否则无法加载。但是,用户肯定希望快速上手,未必愿意阅读文档,去了解模块有哪些属性和方法。
为了给用户提供方便,让他们不用阅读文档就能加载模块,就要用到export default命令,为模块指定默认输出
// my-module.js 默认输出是一个函数
export default function () {
console.log('export default')
}
------------------------------------------------------------
// 其他模块加载该模块时,import命令可以为该匿名函数指定任意名字
import aaa from './my-module'
aaa() // export default
上面的 import 命令,可以用任意名称指向 my-module.js 输出的方法,这时就不需要知道原模块输出的函数名。需要注意的是,这时 import 命令后面,不适用大括号
export default 命令用在非匿名函数前,也是可以的
// my-module.js 默认输出是一个函数
export default function myFun () {
console.log('Hello World!')
}
// 或者写成
function myFun () {
console.log('Hello World!')
}
export default myFun
----------------------------------------------------------------
import myFun from './my-module'
myFun() // Hello World!
上面代码中,foo函数的函数名foo,在模块外部是无效的。加载的时候,视同匿名函数加载。
下面比较一下默认输出和正常输出
// 第一组
export default function crc32() { // 输出
// ...
} import crc32 from 'crc32'; // 输入 // 第二组
export function crc32() { // 输出
// ...
}; import {crc32} from 'crc32'; // 输入
上面代码的两组写法,第一组是使用export default时,对应的import语句不需要使用大括号;第二组是不使用export default时,对应的import语句需要使用大括号
一个模块只能有一个默认输出,所以 export default 命令只能使用一次,正因为如此,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 xxx } from 'modules';
// 等同于
// import xxx from 'modules';
下面代码中,export default a的含义是将变量a的值赋给变量default。所以,最后一种写法会报错。
// 正确
export var a = 1; // 正确
var a = 1;
export default a; // 错误
export default var a = 1;
同样地,因为export default本质是将该命令后面的值,赋给default变量以后再默认,所以直接将一个值写在export default之后
// 正确
export default 42; // 指定对外接口为 default // 报错
export 42; // 没有指定对外的接口
注意:import 和 export 目前无法直接在浏览器中实现,而是需要通过转换器,如:Traceur Compiler、Babel、RollUp 或 Webpack
import 和 export的更多相关文章
- 转:彻底搞清楚javascript中的require、import和export
原文地址:彻底搞清楚javascript中的require.import和export 为什么有模块概念 理想情况下,开发者只需要实现核心的业务逻辑,其他都可以加载别人已经写好的模块. 但是,Ja ...
- Javascript在使用import 与export 区别及使用
一.import与export的用法 1.import的几种用法 import defautName from 'modules.js'; import { export } from 'module ...
- export,import ,export default区别
export,import ,export default区别 一.export,import ,export default ES6模块主要有两个功能:export和import export用于对 ...
- javascript中的require、import和export模块文件
CommonJS 方式 文件输出如math.js: math.add = function(a,b){ return a+b; }exports.math = math; 文件引入: math = r ...
- ES6学习笔记<五> Module的操作——import、export、as
import export 这两个家伙对应的就是es6自己的 module功能. 我们之前写的Javascript一直都没有模块化的体系,无法将一个庞大的js工程拆分成一个个功能相对独立但相互依赖的小 ...
- ES6 模块导入import 导出export 和module.export
ES6中新增了模块的导入和导出功能 在实际过程中可以使用 import 和 export 对模块进行导入和导出操作,具体如下 1. 名字导入/导出 (导入名字必须与导出的一致,导入时需要用花括号) ...
- import、export使用介绍
import.export使用介绍 ES6提供的import.export方法, 使组件化开发模式迈向新高度.本文来介绍import.export的语法及使用方法. 根据 export 的导出方式,可 ...
- export,import ,export default是什么
首先要知道export,import ,export default是什么 ES6模块主要有两个功能:export和importexport用于对外输出本模块(一个文件可以理解为一个模块)变量的接口i ...
- [转]Sqoop-1.4.4工具import和export使用详解
FROM :http://shiyanjun.cn/archives/624.html Sqoop可以在HDFS/Hive和关系型数据库之间进行数据的导入导出,其中主要使用了import和export ...
随机推荐
- C语言中free()函数释放struct结构体中的规律
并不是什么新鲜的事情,不过值得注意.首先我们知道,在使用struct来定义并声明一个变量时,将会自动划分出一个连续的储存空间(虽然根据某些对齐原则会出现内存间隙,但是大体上来说还是连续的)这一块连续空 ...
- 如何删除github上的某个文件夹
在github上只能删除仓库,却无法删除文件夹或文件, 所以只能通过命令来解决 首先进入你的master文件夹下, Git Bash Here ,打开命令窗口 $ git –help 帮助命令 $ g ...
- JVM虚拟机个人理解
针对于java1.8版本,JVM的系统架构 类加载机制: 堆内存结构图: 面试题:一个对象从创建到销毁经历了什么? 1.new一个对象时,在堆内存中开辟一块空间. 2.给开辟的空间分配一个地址. 3. ...
- 关于外网无法访问阿里云主机CentOs
前两天阿里云ECS搞活动,所有买了个三年的Ecs,然后照着之前在虚拟机同样的搭建服务器,一切都很正常,可是 当我配置好防火墙和nginx之后,发现个问题,外网无法访问. 思考: 1.我的nginx没配 ...
- hy这个破项目
最近部署hy记事 这段时间摊上了个挺恶心的项目,叫什么hy鞋同平台..前后左右整的人挺难受的.学到的东西特别少,而且比较浪费时间.不过,还是总结一下吧,好歹花了这么久的时间了 Doc管理xi tong ...
- ubuntu Anaconda install
在文件目录下执行: bash Anaconda3-4.2.0-Linux-x86_64.sh 根据提示输入回车 这里需要查看注册信息,回车浏览完信息即可 阅读完注册信息后,这里输入“yes” 回车即可 ...
- 【计算机篇】目前最好用的 PPT 神器 — iSlide! 一键完成 PPT 设计!
谈到工作中的难题,PPT 这个不起眼的软件,绝对算一个.不同于 Word.Excel,PPT 既要传递信息,还要讲求设计.这很容易使大部分人感觉素材不够,设计不专业或者效率不高.以往为了解决 PPT ...
- VsCode 使用专用编程字体FiraCode
FiraCode资料:https://github.com/tonsky/FiraCode PHP代码效果如下: VsCode 配置中添加: "editor.fontFamily" ...
- Oracle客户端、服务的安装及干净卸载Oracle
软件下载地址: 链接:https://pan.baidu.com/s/1Sluf890eNuaV8muL55eO2w 提取码:oez7 服务端因文件过大,所以分了两个文件压缩包,下载后将内容解压后放置 ...
- ansible基础-roles
一 简介 注:本文demo使用ansible2.7稳定版 在我看来,role是task文件.变量文件.handlers文件的集合体,这个集合体的显著特点是:可移植性和可重复执行性. 实践中,通常我们以 ...