zoukankan      html  css  js  c++  java
  • 《ECMAScript6 入门》

    NVM

    Babel

    babel-core:提供 Babel 的 API,可以获得转码后的代码和抽象语法树。

    babel-polyfill:Babel 只能转换语法,如果想用类似 Promise、Generator 等 API 要 polyfill 她。

    Traceur

    Google 的 JS 代码转换器。

    ECMAScript7

    ES6 的草案封闭,不再接受新功能,新功能将加入 ES7。

    TC39 提案的流程:

    • Stage0: Strawman 展示
    • Stage1: Proposal 征求意见
    • Stage2: Draft 草案(到这里基本就定了要加入标准里了)
    • Stage3: Candidate 候选
    • Stage4: FInished 定案

    letconst

    let: 块级作用域、无变量提升(var有变量提升)、有暂存性死区(TDZ, temporal dead zone)、不允许重复声明。

    有了块级作用域立即执行函数就不怎么需要了

    // IIFE
    (function(){
      var foo = ...;
      ...
    })()
    
    // 块级作用域
    {
      let foo = ...;
      ...
    }
    

    const: let的基础上添加了不能修改其值的特性。对于const声明的对象会保证其地址不能修改,要想不让修改对象的属性要用Object.freeze()

    letconstclass声明的全局变量不属于全局对象windowvarfunction声明的全局变量还属于全局对象window

    解构(Destructuring)

    解构赋值允许指定默认值。

    在解构赋值中,等号右边的值如果不是对象就先将其转为对象。nullundefined无法转换为对象会报错。

    只有解构赋值语句的非模式部分(待赋值的变量名部分)可以使用圆括号。

    扩展运算符

    数组作为创建对象参数

    // ES5 
    /*
    * 1. bind 的第一个参数用 new 的时候会忽略 The value to be passed as the this parameter to the target function when the bound function is called. The value is ignored if the bound function is constructed using the new operator.
    * 2. new Date() 和 new Date 一样
    */
    new (Date.bind.apply(Date, [null, 2012, 11, 21]));
    // ES6
    new Date(...[2012, 11, 21]);
    

    正确处理 32 位的 Unicode 字符串

    > let str = 'xuD83DuDe80y';
    > [...str].length // 正确
    3
    > str.split('').length // 错误
    4
    > [...str].reverse().map(d => d.codePointAt(0).toString(16)) // 正确
    [ '79', '1f680', '78' ]
    > str.split('').reverse().map(d => d.codePointAt(0).toString(16)) // 错误
    [ '79', 'de80', 'd83d', '78' ]
    

    调用帧、调用栈

    函数调用会形成调用帧(call frame),所有调用帧形成调用栈(call stack)。

  • 相关阅读:
    Spring Boot 学习(一) 快速搭建SpringBoot 项目
    @RunWith和 SpringJUnit4ClassRunner ---->junit4和Spring一起使用
    Spring Boot的SpringApplication类详解
    @SpringBootApplication的使用
    使用阿里云搭建个人博客
    @Controller和@RestController的区别?
    蚂蚁金服开发文档中心
    Logger.getLogger()和LogFactory.getLog()的区别
    SimpleDateFormat使用详解
    SpringBoot整合RabbitMQ实现微服务间的异步消息沟通
  • 原文地址:https://www.cnblogs.com/jffun-blog/p/11108399.html
Copyright © 2011-2022 走看看