即日起开始记录学习 ES6 的语法笔记,以巩固以前学习过的知识并学习新的知识以备 React、MeteorJS 新框架的学习。其中 ES6 全部学习资源来自网络阮一峰编写的图书:http://es6.ruanyifeng.com/,其中记录的代码或联系可能与书中重复。一些与历史相关的资料请阅读书中内容,我仅记录自己学习过程中遇到的问题和与历史语法不一致的内容,以下进入正题。

node 环境部署

通过书中可以看到,node 对 ES6 的支持要比浏览器好,所以我们尽量在 node 中学习 ES6 语法,这样可以学习的功能也更多一些。我 Mac 中安装了 brew,所以用 brew 来安装 node。

1
brew install node

使用如下命令可以查看 node 支持哪些 ES6 新特性。

1
node --v8-options  grep harmony

安装 Babel,这里注意要全局安装,否则 babel-node 命令无效。

1
npm install -g babel-cli

新建一个学习的目录,然后执行如下命令安装解析支持库。

1
2
npm install --save-dev babel-preset-es2015
npm install --save-dev babel-preset-react

项目目录下创建一个名为 .babelrc 的配置文件,并填进去如下内容:

1
2
3
4
5
6
7
{
"presets": [
"es2015",
"react"
],
"plugins": []
}

这样我们环境其实就已经可以使用了,创建一个 index.js 的测试文件,编写如下测试代码。

1
2
3
4
5
let [a, b, c] = [11, 22, 33];

console.log(a);
console.log(b);
console.log(c);

然后运行 babel-node index.js 命令,就可以看到输出效果了。上面代码 let 和结构赋值都是 ES6 的新特性。 现在的环境足够我们学习一些基础语法了,你可以根据书中的资料进一步安装其他支持库,比如 babel-register 等。更进一步的复杂环境,我们其实可以安装一些框架,利用框架部署好的集成环境来学习 ES6,不过我觉得那样就由点大炮打蚂蚁的意思了,还是先从最基础的环境学起对自己有好处。