ES6 系列一之开发环境配置

随着时间的推移,浏览器对ES6支持度已经越来越高了,超过90%的 ES6 语法特性都实现了。虽然有些浏览器对ES6的支持程度已经很高了(Chrome59 97%,Safari10 99%),但是很多人使用的IE对ES6的支持任然很不理想(IE11 11%),所以在实际工程应用中,我们还需要将ES6转化成ES5。各大浏览器的最新版本,对 ES6 的支持可以查看kangax.github.io/es5-compat-table/es6/。

环境支持

Node 是 JavaScript 的服务器运行环境(runtime)。它对 ES6 的支持度更高,除了那些默认打开的功能,还有一些语法功能已经实现了,但是默认没有打开。使用下面的命令,可以查看 Node 已经实现的 ES6 特性。

node --v8-options | grep harmony

上面命令的输出结果,会因为版本的不同而有所不同。

转码

通过特定的转码器,如Babel,或在线的转换器,将ES6转换成ES5再进行部署。

Babel 是一个广泛使用的 ES6 转码器,可以将 ES6 代码转为 ES5 代码,从而在现有环境执行。这意味着,你可以用 ES6 的方式编写程序,又不用担心现有环境是否支持。相对于之前的Babel5,Babel6不再是一个整的大的package,而是拆分了很多个小的package可供选择安装,可以根据项目进行自定义。下面介绍Babel的开发环境的配置。

1. 命令行使用(手动编译)

  1. 安装babel-cli,支持命令行使用babel
npm install --save-dev babel-cli

完成之后,我们还不能编译ES6文件,因为 babel 不再包含任何 transform 功能,babel6里把它们作为插件(plugin)分割出去,需要我们自己定义。

  1. 安装babel-preset-env
    要想编译ES6文件,我们必须安装相关的插件,babel-preset-env打包了所有用于转换ES6的插件,安装babel-preset-env:
npm install --save-dev babel-preset-env

babel还有babel-preset-es2015,babel-preset-es2016等插件,每一年的preset仅编译那一年的批准的规则,而babel-preset-env则包含es2015,es2016,es2017和latest等。

  1. 配置
    安装完babel-preset-env之后,还需要一步,在package.json或.babelrc文件启用babel-preset-env:
"babel": { 
   "presets": [ 
       "env" 
   ] 
}
  1. 编译
    完成以上安装后,就可以编译文件了:
# 转码结果输出到标准输出
babel example.js
# 转码结果写入一个文件 --out-file 或 -o 参数指定输出文件
babel example.js --out-file compiled.js
# 转码整个目录 --out-dir 或 -d 参数指定输出目录
babel src --out-dir lib
#忽略spec和test文件
babel src --out-dir lib --ignore spec.js,test.js
# -s 参数生成source map文件
babel src -d lib -s

更多选项

2. Webstorm编译(IDE)

  1. 开启ES6语法支持
    Webstorm已经支持ES6语法了,但是默认情况下没有开启,需要我们手动开启,打开Preferences->Languages & Frameworks->JavaScript,在选项中设置为ES6。


    image.png
  2. 安装babel-cli和babel-preset-env

npm install --save-dev babel-preset-env babel-cli
  1. 配置babel File Watcher
    File Watcher是一个Webstorm内置工具,可以在文件发生变化时自动执行相关命令,对于babel,已经有预存的配置,我们激活配置即可使用:
    Preferences->Tools->File watchers
    点击'+'按钮,选择babel,在File watcher配置中,指定babel-cli在node_modules中的路径:
    image.png

    在Webstorm 2017.1中,编译过的文件存放在dist文件夹中,可以自己设置输出文件路径,输入文件路径,编码的文件类型等参数,更多配置请参考Webstorm官网。当然,你也可以在package.json或者.babelrc配置文件中指定,添加适合你工程的配置。

3.VS Code配置

  1. 安装babel-cli和babel-preset-env
npm install --save-dev babel-cli babel-preset-env
  1. 配置package.json,设置生成souremaps
{
  "scripts": {
    "build": "babel src -d dist --source-maps"
  }
}
  1. 在.vscode目录下的tasks.json文件中写入如下配置,如果没有这个文件,就创建一个
{
    "version": "0.1.0",
    "command": "npm",
    "isShellCommand": true,
    "showOutput": "always",
    "suppressTaskName": true,
    "tasks": [
        {
            "taskName": "build",
            //此处第二个参数"build"要与上一步中的scripts中的编译脚本的名字一样
            "args": [ "run", "build" ],
            "isBuildCommand": true
        }
    ]
}
  1. 打开.vscode目录下的launch.json文件,在 configurations中添加如下配置,通过使用preLaunchTask
    在启动前进行编译,如果没有launch.json文件,打开调试,在启动程序一栏,下拉,添加配置即可
    "configurations": [
        {
            "type": "node",
            "request": "launch",
            "name": "启动程序",
            "program": "${workspaceRoot}/src/index.js",//需要编译的文件
            "stopOnEntry": false,
            "args": [],
            "cwd": "${workspaceRoot}",
            //此处的"build"要和上一步的tasks中的taskName一样
            "preLaunchTask": "build",
            "runtimeExecutable": null,
            "runtimeArgs": ["--nolazy"],
            "env": {
                "NODE_ENV": "development"
            },
            "sourceMaps": true,
               "outFiles": [
                "${workspaceRoot}/dist"//输出文件的目录
            ]
        }
    ]
image.png
  1. 启动调试或者按F5,就可以在输出目录下看到编译好的文件

4. 浏览器环境

Babel 也可以用于浏览器环境。但是,从 Babel 6.0 开始,不再直接提供浏览器版本,而是要用构建工具构建出来。如果你没有或不想使用构建工具,可以使用babel-standalone模块提供的浏览器版本,将其插入网页。

<script src="https://cdnjs.cloudflare.com/ajax/libs/babel-standalone/6.4.4/babel.min.js">
</script>
<script type="text/babel">
// Your ES6 code
</script>

注意,网页实时将 ES6 代码转为 ES5,对性能会有影响。生产环境需要加载已经转码完成的脚本。
更多转换方法请参考 《ECMAScript 6 入门》

5. 关于Babel

  1. babel-node
    babel-cli工具自带一个babel-node命令,提供一个支持ES6的REPL(Read-Eval-Print-Loop)环境。它支持Node的REPL环境的所有功能,而且可以直接运行ES6代码。它不用单独安装,而是随babel-cli一起安装。然后,执行babel-node就进入REPL环境。
#进入REAL环境
babel-node
#babel-node命令可以直接运行ES6脚本(.js可以省略)
babel-node test.js
#babel-node也可以安装在项目中
npm install --save-dev babel-cli
  1. babel-polyfill
    这将模拟一个完整的ES2015 +环境,旨在用于应用程序而不是库/工具。Babel 默认只转换新的 JavaScript 句法(syntax),而不转换新的 API,比如Iterator、Generator、Set、Maps、Proxy、Reflect、Symbol、Promise等全局对象,以及一些定义在全局对象上的方法(比如Object.assign)都不会转码。
    举例来说,ES6 在Array对象上新增了Array.from方法。Babel 就不会转码这个方法。如果想让这个方法运行,必须使用babel-polyfill,为当前环境提供一个垫片。
#因为它是一个填充工具(在源码之前运行),所以它是一个dependency,而不是devDeoendencynpm 
install --save babel-polyfill

然后在程序的入口包含polyfill,确保在其他引用声明之前调用

#node
require("babel-polyfill");
#es6
import("babel-polyfill");

当使用webpack时,在webpack.config.js文件的入口数组中添加babel-polyfill:

module.exports = {
  entry: ["babel-polyfill", "./app/js"]
};

参考文献

  1. 《ECMAScript 6 入门》
  2. WebstormBabel 官方文档
  3. debugging in Visual Studio Code with babel-node

说明

所有内容都已在macOS Sierra 10.12.5,cnpm@4.5.0,npm@3.10.10,node@6.10.2,babel-cli@6.24.1,babel-preset-env@1.5.2,Webstorm 2017.1,VS Code@1.13.1环境下实现并验证。
PS:初次写作,如有不足与错误之处,请多多指教。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 157,298评论 4 360
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 66,701评论 1 290
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 107,078评论 0 237
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,687评论 0 202
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,018评论 3 286
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,410评论 1 211
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,729评论 2 310
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,412评论 0 194
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,124评论 1 239
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,379评论 2 242
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 31,903评论 1 257
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,268评论 2 251
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 32,894评论 3 233
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,014评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,770评论 0 192
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,435评论 2 269
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,312评论 2 260

推荐阅读更多精彩内容