export与export default的区别

node中导入模块:var 名称 = require(‘模块标识符’)

node中向外暴露成员的形式:module.exports = {}

在ES6中,也通过规范的形式,规定了ES6中如何导入和导出模块

ES6中导入模块,使用 import 模块名称 from ‘模块标识符’ import ‘表示路径’

import * from * 是ES6中导入模块的方式

在ES6中,使用export default 和 export 向外暴露成员

例如:

1
2
3
4
5
// test.js
export default {
name: 'zs',
age: 20
}

或是

1
2
3
4
5
6
// test.js
var info = {
name: 'zs',
age: 20
}
export default info

在main.js中接收,test.js使用export default 向外暴露的成员

1
2
import person from './test.js'
console.log(person);

注意:

1、export default 向外暴露的成员,可以使用任意变量来接收

2、在一个模块中,export default 只允许向外暴露一次

3、在一个模块中,可以同时使用export default 和export 向外暴露成员

4、使用export向外暴露的成员,只能使用{ }的形式来接收,这种形式,叫做【按需导出】

5、export可以向外暴露多个成员,同时,如果某些成员,在import导入时,不需要,可以不在{ }中定义

6、使用export导出的成员,必须严格按照导出时候的名称,来使用{ }按需接收

7、使用export导出的成员,如果想换个变量名称接收,可以使用as来起别名

例如:

1
2
3
4
5
6
7
8
9
10
// test.js
var info = {
name: 'zs',
age: 20
}
export default info

export var title = '小星星'

export var content = '哈哈哈'

在main.js中接收,test.js使用export default 和 export 向外暴露的成员

1
2
3
import person, {title, content as content1} from './test.js'
console.log(person);
console.log(title + '=======' + content1);

export与export default的区别
https://zouhualu.github.io/20210701/export与export-default的区别/
作者
花鹿
发布于
2021年7月1日
许可协议