zoukankan      html  css  js  c++  java
  • 必备技能二、es6

    一、ES6模块

    ES6 引入了模块化,其设计思想是在编译时就能确定模块的依赖关系,以及输入和输出的变量。

    ES6 的模块化分为导出(export) @与导入(import)两个模块。

    特点

    ES6 的模块自动开启严格模式,不管你有没有在模块头部加上 use strict;。

    模块中可以导入和导出各种类型的变量,如函数,对象,字符串,数字,布尔值,类等。

    每个模块都有自己的上下文,每一个模块内声明的变量都是局部变量,不会污染全局作用域。

    每一个模块只加载一次(是单例的), 若再去加载同目录下同文件,直接从内存中读取。

    export 与 import

    导出的函数声明与类声明必须要有名称

    import 命令会提升到整个模块的头部,首先执行。

    /*-----export [test.js]-----*/
    let myName = "Tom";
    let myAge = 20;
    let myfn = function(){
        return "My name is" + myName + "! I'm '" + myAge + "years old."
    }
    let myClass =  class myClass {
        static a = "yeah!";
    }
    export { myName, myAge, myfn, myClass }
     
    /*-----import [xxx.js]-----*/
    import { myName, myAge, myfn, myClass } from "./test.js";
    console.log(myfn());// My name is Tom! I'm 20 years old.
    console.log(myAge);// 20
    console.log(myName);// Tom
    console.log(myClass.a );// yeah!

    建议使用大括号指定所要输出的一组变量写在文档尾部,明确导出的接口。

    函数与类都需要有对应的名称,导出文档尾部也避免了无对应名称。

    export default 命令

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

    export default 中的 default 是对应的导出接口变量

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

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

    var a = "My name is Tom!";
    export default a; // 仅有一个
    export default var c = "error"; 
    // error,default 已经是对应的导出变量,不能跟着变量声明语句
     
    import b from "./xxx.js"; // 不需要加{}, 使用任意变量接收
    

      

  • 相关阅读:
    域名和IP地址的关系通俗解释
    简单卷、跨区卷、带区卷、镜像卷和 RAID5的区别
    什么是网络端口
    Windows7 64 bit 下解决:检索 COM 类工厂中 CLSID 为 {0002450000000000C000000000000046} 的组件时失败
    SQL函数,收藏先。
    C#中抽象类和接口的区别(转)
    SQL数据库碎片检查DBCC SHOWCONTIG含义
    SQL锁表语句
    50种方法优化SQL Server
    简单工厂模式(转)
  • 原文地址:https://www.cnblogs.com/qdwz/p/11422812.html
Copyright © 2011-2022 走看看