JavaScript 学习笔记– ES6学学(一)介绍以及Babel的应用

正文摘自阮一峰先生的《ECMAScript
6入门》,原文地址:http://es6.ruanyifeng.com/\#docs/intro

 

ECMAScript 6
是一个泛指,含义是5.1本子后的JavaScript的子弟标准,涵盖了ES2015,
ES2016, ES2017等。

Babel转码器是一个广大接纳的ES6转码器,可以将ES6转码为ES5。

 

布局文件:.babelrc

配置文件中央格式:

// .babelrc
{
  “presets”: [],
  "plugins": [],
}

行使babel先要安装规则集,安装完后加盟到布置文件中。官方的规则集如下:

# ES2015转码规则 
$ npm install --save-dev babel-preset-es2015 

# react转码规则 
 $ npm install --save-dev babel-preset-react 

# ES7不同阶段语法提案的转码规则(共有4个阶段),选装一个 
$ npm install --save-dev babel-preset-stage-0 
 $ npm install --save-dev babel-preset-stage-1 
 $ npm install --save-dev babel-preset-stage-2 
 $ npm install --save-dev babel-preset-stage-3

// .babelrc
{
    "presets": [
      "es2015",
      "react",
      "stage-2"
    ],
    "plugins": []
  }

 

babel-ci 模块

babel-ci模块是在指令行中使用babel,
使用babel命令可以平昔对文本举行转码,对于项目以来,可以一向将其写在package.json中,然后将指令放在scripts
中。

设置命令如下:

$ npm install --global-cli

 

基本用法如下:

# 转码结果输出到标准输出
$ babel example.js

# 转码结果写入一个文件
# --out-file 或 -o 参数指定输出文件
$ babel example.js --out-file compiled.js
# 或者
$ babel example.js -o compiled.js

# 整个目录转码
# --out-dir 或 -d 参数指定输出目录
$ babel src --out-dir lib
# 或者
$ babel src -d lib

# -s 参数生成source map文件
$ babel src -d lib -s

在档次中装载和运用babel-cli:

# 安装
$ npm install --save-dev babel-cli

// package.json
{
  // ...
  "devDependencies": {
    "babel-cli": "^6.0.0"
  },
  "scripts": {
    "build": "babel src -d lib"
  },
}

 

babel-register 模块

babel-register模块改写require命令,为它助长一个钩子,此后,每当使用require加载.js,
.jsx, 和.es6后缀名的文件,就会先用Babel举办转码:

$ npm install --save-dev babel-register

require("babel-register");
require("./index.js");

注意:
babel-register只会对require命令加载的文书转码,而不会对当前文件转码。

 

Babel可以用来浏览器环境,可是从6.0版本起先,不再直接提供浏览器版本,而是要用构建工具构建出来。

babel 和browserify 配合使用:

{   
  "browserify": 
  {     
    "transform": [["babelify", { "presets": ["es2015"] }]]   
  } 
}