ES6中export 、import、export default 的用法和区别

ES6模块主要有两个功能:exprot 和 import

 

  • export 主要用于对外输出本模块变量的一个接口
  • import用于在一个模块中加载另一个含有export接口的模块

也就是说使用export命令定义了模块对外输出的接口以后其他模块通过import命令进行加载这个模块

// until.js
var name = "boy";
var getName =function(name){
   console.log(name);
}
export {name,getName};
// 在大括号中添加name,getName变量,在通过export输出,就可以将对应的变量值以name,getName变量标识符形式暴露给其他的文件而被读取到
//不能直接写成export name 这样的形式,如果这样就相当于直接export "boy"了,外部文件就无法读取到文件内部的name的值

上面也可以换另一种的写法输出变量
export var name = 'boy';
export function getName(name){
    console.log(name)
}
// import 通过import进行获取js中的文件的内部变量,{}括号内的变量来自于js文件export出的变量标识符。
import{name,getName} from './until.js'

上面使用了export 导出变量,然后通过import获取到js文件中的内部变量,从而可以获取到内部的值.
下面是export default :

// until.js
var obj ={}
obj.name="boy";
obj.getName=function(name){console.log(name)};
export default obj
// export default 不能加{};一个文件内最多只能有一个export default。
import obj from './until.js'
import obj1 from './until.js'
// export default 输出一个叫做default 的变量,然后系统可以允许你为它取任意名字,所以可以为import的模块取任何变量名,且不需要大括号。

从上面我们看出export default 和 export 的主要区别在于对应的import的区别:

export 对应的import 需要知道export 抛出的变量名或函数名 import{name,getName}
export default 对应的import 不需要知道export 抛出的变量名或函数名import anyName

 

 

 

你可能感兴趣的:(ES6中export 、import、export default 的用法和区别)