分别暴露、统一暴露以及默认暴露三者的区别

一、分别暴露 export

1.注意:export命令规定的是对外的接口,必须与模块内部的变量建立一一对应关系。

// 报错

export 1;

// 报错

var m = 1;

export m;

2.所谓变量,其实只有在声明时的一瞬间有,声明过后,不管是单独使用,还是作为实参传递,它都是作为一个表达式,而不是变量。

二、统一暴露 export {}

1. 统一暴露的语法 export {} 中 {} 是一个对象吗?

export {} 是作为一个整体的语法存在,在{}中放入的是模块需要对外暴露内部变量,在形式上其实这里{}更像是一个数组,其数组元素就是模块内部变量。

三、默认暴露 export default

1. 默认暴露和上面两种暴露最大的区别是,一个模块中默认暴露只能使用一次,而export 和 export {} 可以使用多次。

2. 默认暴露主要场景就是,针对一个模块只暴露一个接口的场景。

3.export 只暴露一个接口的场景:导出时需要满足一一对应要求,导入时需要使用import {}命令接收

// b.js

export function b(){

    console.log('b')

}

// a.js

import {b} from './b.js'

4. export {} 只暴露一个接口的场景:导出时必须要搞一个变量名给export {} 命令,否则export {} 无法获取变量,且必须使用 import {} 命令接收

// b.js

var b = function(){

    console.log('b')

}

export {b}

// a.js

import {b} from './b.js'

5. export default 由于默认暴露只能暴露一个接口,所以这个接口不需要名字就可以限定,同时模块只会暴露一个接口给import,所以import也不需要名字限定,直接导出该接口即可,接口名可以任意定.

// b.js

export default function(){

    console.log('b')

}

// a.js

import haha from './b.js'

四、注意

export命令可以出现在模块的任何位置,只要处于模块顶层就可以。如果处于块级作用域内,就会报错,下一节的import命令也是如此。 需要注意的是,import和export命令是在编译期间工作的,而无论是无论是函数块,if块,代码块,它们之中的代码都是在运行期间才能生效的,所以必须将import和export命令放置于模块顶层。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值