美文网首页
ES6中 import、 export default 和 ex

ES6中 import、 export default 和 ex

作者: 古德毛宁_39de | 来源:发表于2018-11-22 11:46 被阅读0次


    ES6实现了模块功能export和import

    在ES6出现之前,已经出现了解决js模块加载的方案,最主要的是CommonJS和AMD规范。CommonJS主要应用于服务器,实现同步加载,如nodejs。AMD规范应用于浏览器,如requirejs,为异步加载。同时还有CMD规范,为同步加载方案如seaJS。

    ES6在语言规格的层面上,实现了模块功能,而且实现得相当简单,完全可以取代现有的CommonJS和AMD规范,成为浏览器和服务器通用的模块解决方案。

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

    export用于对外输出本模块(一个文件可以理解为一个模块)变量的接口

    import用于在一个模块中加载另一个含有export接口的模块

    export default 和 export 的区别

    1. export与export default均可用于导出常量、函数、文件、模块等

    2. 可以在其它文件或模块中通过import+(常量 | 函数 | 文件 | 模块)名的方式,将其导入,以便能够对其进行使用

    3. 在一个文件或模块中,export、import可以有多个,export default仅有一个

    4. 通过export方式导出,在导入时要加{ },export default则不需要

    5. 其实很多时候export与export default可以实现同样的目的,只是用法有些区别。注意第四条,通过export方式导出,在导入时要加{ },export default则不需要。使用export default命令,为模块指定默认输出,这样就不需要知道所要加载模块的变量名

    // export 导出案例 demo1.js

    export const str = 'hello'

    export function init1 () {

      console.log('hello')

    }

    export const init2 = () => {

      console.log('hello)

    }

    export class INIT {

      constructor() {

        console.log('hello')

        this.init()

      }

      init () {

        console.log('hello')

      }

    }

    // 对应导入方式 demo2.js ,可按需导入

    import { str, init1, init2, INIT } from 'demo1.js

    // export default 导出案例 demo1.js

    const str = 'hello'

    // 此处相当于为str变量值"hello"起了一个系统默认的变量名default,自然default只能有一个值,所以一个文件内不能有多个export default

    export default str

    // export default 导出案例 demo2.js

    const str1 = 'hello'

    export default {

      str1: str1,

      str2: 'hi'

    }

    // 对应导入方式 demo3.js

    import a from 'demo1.js'

    import b from 'demo2.js'

    console.log(a)

    console.log(b)

    // 本质上,demo1.js文件和demo2.js文件的export default输出一个叫做default的变量,然后系统允许你为它取任意名字,本案例中取名为a和b。

    // 所以可以为import的模块起任何变量名,且不需要用大括号包含

    切记,注意以下代码的区别

    export default const a =1    // 错误

    const a =1

    export default a   // 正确

    export const a =1    // 正确


    const/let是ES6关键字,如果default后跟const之类的关键字是不符合的,

    ES6规范中标记出了default后面能带的参数

    究其本质,export default 命令其实,是将该命令后面的值赋给default变量以后再默认,只是输出了一个叫做 default 的变量,所以export default的后面不能跟变量声明语句

    export default a 的含义是将变量a的值赋给变量default

    相关文章

      网友评论

          本文标题:ES6中 import、 export default 和 ex

          本文链接:https://www.haomeiwen.com/subject/hpxlqqtx.html