#每日一记# 3分钟从 es6+ 编译成 es5 的代码里学习知识

424 阅读4分钟

每日一记 - 但并不日更

新系列导读

学习编程语言是一件持之以恒的事情,从学会简单的语法就能写出程序,到理解类型和设计模式,再到考虑代码的组织架构。谁不是从这样一点点深入和积累的呢?入门总是轻松又令人愉悦的,但随着知识点越来越多学习的曲线却骤然陡峭。但随着对语言的深入理解,再回头来重新审阅基本的知识,又会有柳暗花明又一村的豁然感,「啊,原来是这样的」那种感觉。

这个**「3分钟」**系列将利用 babel 在线的实时编译工具,来学习分析 es6+ 的部分特性。通过编译后的 es5 代码,我们可以从中了解到 es6+ 特性的实现细节,更好的掌握新特性的适用性。

作为系列的第一篇,先介绍这个 babel 在线实时编译工具。

babel

「今天,使用下一代 Javascript 编程」,正如 babel 官网的标语,babel 正是为抹平 高速扩展的 JS 标准缓慢实现标准的浏览器 产生的鸿沟而出现的。babel 最大的功能就是将浏览器还未支持的语法编译成低版本 js 语法,让其能正常运行。

首先打开页面 babel 在线实时编译

界面

界面分为三大区域:设置区源码区编译区

设置区

主要进行编译方式的设置和编译环境的设置。

我们主要关心编译环境(PRESETS) 的设置,比如你希望引入的环境编译包(lib)。图中所示的就是引入了 es2015stage-3 两个编译包,编译器就会先对源码进行 stage-3 的特性进行编译,再对 es2015 的特性进行编译。需要注意的是,如果只开启 es2015 那么只会编译 es2015 中新增的特性,更加新颖的特性就无法识别出来。

让我们来举个例子:箭头函数是 es2015 的新特性,而算数运算符幂运算 **es2016 的新特性,那么在编译环境里只选择 es2015 会发生什么呢?

// v6.26.0
// presets: es2015
// 源码区
let foo = {
    bar: () => {
    	return true;
    },
    baz: 10 ** 2,
}

// 编译区
"use strict";

var foo = {
  bar: function bar() { // 只有 es2015 的箭头函数被编译了 
    return true;
  },
  baz: 10 ** 2
};

如果在编译环境里只选择 es2016 会发生什么呢?

// v6.26.0
// presets: es2016
// 源码区
let foo = {
    bar: () => {
    	return true;
    },
    baz: 10 ** 2,
}

// 编译区
let foo = {
    bar: () => {
        return true;
    },
    baz: Math.pow(10, 2) // 只有 es2016 的幂运算符被编译了
};

所以如果想让所有新特性都被编译成 es5 那么最好同时选择 es2015stage-3 两个编译包。

// v6.26.0
// presets: es2015 stage-3
// 源码区
let foo = {
    bar: () => {
    	return true;
    },
    baz: 10 ** 2,
}

// 编译区
"use strict";

var foo = {
    bar: function bar() {
        return true;
    },
    baz: Math.pow(10, 2)
};

// 特性都被编译了
源码区和编译区

在源码区输入代码,在编译区就能实时显示编译后的代码。

示例解读

在这个系列里的代码示例,为了可读性都不会使用截图,而是用代码编写,在代码头部添加注释以方便阅读代码的人知道代码的编译环境和编译细节。

代码会包含使用的编辑器版本

// v6.26.0

包含使用的编译包

// es2016

结语

由于 ES 的新特性主要包含两个方面,一个是对现有对象的扩展,比如 Object.assing();另一方面是对语法的扩展,比如新语法和语法糖。这个**「3分钟」** 系列也将着重介绍对语法的扩展。

谢谢。

罗小黑写写文字

如果喜欢文章 请留下一个赞~ 如果喜欢文章 分享给更多人~

掘金中关注我 在简书中关注我

自由转载-非商用-非衍生-保持署名(创意共享3.0许可证) 转载时请保留原文链接 以保证可及时获取对文章的订正和修改