Node中使用ES6语法的基础教程

2020-06-17 07:01:34易采站长站整理

相关背景介绍

我们现在大多数人用的语法javascript 其实版本是ecmscript5,也是就es5。这个版本己经很多年了,且完美被各大浏览器所支持。所以很多学js的朋友可以一直分不清楚es5和javscript的关系。javascript是一门编程语言,那么它就会有版本,es5还是es6 就就是它的版本号。最新版es7己经在紧锣密布的进行中,它最新的语法会让我们写代码更新的行云流水。

引言

Node本身已经支持部分ES6语法,但是import export,以及async await(Node 8 已经支持)等一些语法,我们还是无法使用。为了能使用这些新特性,我们就需要使用babel把ES6转成ES5语法

安装babel


npm install babel-cli -g

<!– more –>

基础知识

babel的配置文件是.babelrc


{
"presets": []}

新建一个demo文件夹,文件夹下新建 1.js


const arr = [1, 2, 3];
arr.map(item => item + 1);

同时新建.babelrc配置文件


{
"presets": []}

终端运行


babel 1.js -o dist.js

可以看见,在文件夹下,新建了一个dist.js,这就是babel转码后的文件

但是,dist.js目前是没有任何变化的,因为我们在配置文件里面没有声明转码规则,所以babel无法转码

安装转码插件


npm install --save-dev babel-preset-es2015 babel-preset-stage-0

修改配置文件


{
"presets": [
"es2015",
"stage-0"
]}

es2015可以转码es2015的语法规则,stage-0可以转码ES7语法(比如async await)

再次运行终端


babel 1.js -o dist.js

可以看见,箭头函数被转码了


var arr = [1, 2, 3];
arr.map(function (item) {
return item + 1;
});

我们试下async await


async function start() {
const data = await test();
console.log(data);
}
function test() {
return new Promise((resolve, reject) => {
resolve('ok');
})
}

转码后的文件


'use strict';
var start = function () {
var _ref = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee() {
var data;
return regeneratorRuntime.wrap(function _callee$(_context) {
while (1) {
switch (_context.prev = _context.next) {
case 0:
_context.next = 2;