ES6的语法,nodeJs、浏览器不必定都支持,不一样版本的支持状况不同。在学习过程当中,如何肯定是本身写的代码有问题,仍是运行环境不支持呢?html
首先,浏览器端通常支持的特性有限(好吧,我刚查了,最新的不包括IE11浏览器ES6支持很好,可是手机端支持很差,那就要考虑到浏览器的多样性),因此我使用nodeJs环境。node
更多平台支持es6状况es6
查看nodeJs的v8版本github
node -p process.versions.v8
查看本地nodeJs版本 In progress特性npm
node --v8-options | grep "in progress"
更多 https://nodejs.org/en/docs/es6/浏览器
babel能够将不支持的特性转化成ES5支持的写法。babel
工程根目录.babelrc
ide
好比下面es2015,会将全部的ES6写法转换成ES5,可是原本nodeJs原生支持的,都转化了,对性能很差。性能
"presets": [ "babel-preset-es2015" ]
首先要清楚你要使用哪些特性,对不支持的特性,选择须要的babel插件,有针对的转化。好比我本地是nodeJs是v5.6.0。
http://node.green/搜索strict mode
,发现许多语法须要,好比如下错误。为了以防万一,全部模块都加。我就加了插件transform-strict-mode。
SyntaxError: Block-scoped declarations (let, const, function, class) not yet supported outside strict mode
为了保险,要使用的harmony的特性也转化下
相应的,我又加了其它插件。
"plugins": [ "transform-strict-mode", "transform-es2015-modules-commonjs", "transform-es2015-destructuring", "transform-es2015-parameters" ]
npm install --save-dev babel-cli -g npm install --save-dev babel-preset-es2015
开发中,使用babel-node test.js
运行代码
发布,使用babel src --out-dir lib
生成转化后代码
注意:babel-node和babel命令,都接受.babelrc配置
babel也有浏览器端的,引入转码Js。就能够es6写代码直接跑起来。
http://babeljs.io/docs/plugins/
ES6中,模块默认就是strict mode;而且上面经过babel插件,每一个js自动注入了"use strict";
在ES5中,严格模式有些要求,咱们在写ES6时也要遵循。