mirror of
https://github.com/ruanyf/es6tutorial.git
synced 2025-05-24 18:32:22 +00:00
feat(intro): 重写Traceur的介绍
This commit is contained in:
parent
8ad3c20f5f
commit
ffe44108ea
@ -47,7 +47,7 @@ Node.js是JavaScript语言的服务器运行环境,对ES6的支持度比浏览
|
|||||||
安装nvm需要打开命令行窗口,运行下面的命令。
|
安装nvm需要打开命令行窗口,运行下面的命令。
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
$ curl -o https://raw.githubusercontent.com/creationix/nvm/<version number>/install.sh | bash
|
$ curl -o- https://raw.githubusercontent.com/creationix/nvm/<version number>/install.sh | bash
|
||||||
```
|
```
|
||||||
|
|
||||||
上面命令的`version number`处,需要用版本号替换。本节写作时的版本号是`v0.29.0`。该命令运行后,`nvm`会默认安装在用户主目录的`.nvm`子目录。
|
上面命令的`version number`处,需要用版本号替换。本节写作时的版本号是`v0.29.0`。该命令运行后,`nvm`会默认安装在用户主目录的`.nvm`子目录。
|
||||||
@ -468,20 +468,20 @@ Google公司的[Traceur](https://github.com/google/traceur-compiler)转码器,
|
|||||||
|
|
||||||
Traceur允许将ES6代码直接插入网页。首先,必须在网页头部加载Traceur库文件。
|
Traceur允许将ES6代码直接插入网页。首先,必须在网页头部加载Traceur库文件。
|
||||||
|
|
||||||
```javascript
|
```html
|
||||||
<!-- 加载Traceur编译器 -->
|
<script src="https://google.github.io/traceur-compiler/bin/traceur.js"></script>
|
||||||
<script src="http://google.github.io/traceur-compiler/bin/traceur.js"
|
<script src="https://google.github.io/traceur-compiler/bin/BrowserSystem.js"></script>
|
||||||
type="text/javascript"></script>
|
<script src="https://google.github.io/traceur-compiler/src/bootstrap.js"></script>
|
||||||
<!-- 将Traceur编译器用于网页 -->
|
<script type="module">
|
||||||
<script src="http://google.github.io/traceur-compiler/src/bootstrap.js"
|
import './Greeter.js';
|
||||||
type="text/javascript"></script>
|
|
||||||
<!-- 打开实验选项,否则有些特性可能编译不成功 -->
|
|
||||||
<script>
|
|
||||||
traceur.options.experimental = true;
|
|
||||||
</script>
|
</script>
|
||||||
```
|
```
|
||||||
|
|
||||||
接下来,就可以把ES6代码放入上面这些代码的下方。
|
上面代码中,一共有4个`script`标签。第一个是加载Traceur的库文件,第二个和第三个是将这个库文件用于浏览器环境,第四个则是加载用户脚本,这个脚本里面可以使用ES6代码。
|
||||||
|
|
||||||
|
注意,第四个`script`标签的`type`属性的值是`module`,而不是`text/javascript`。这是Traceur编译器识别ES6代码的标志,编译器会自动将所有`type=module`的代码编译为ES5,然后再交给浏览器执行。
|
||||||
|
|
||||||
|
除了引用外部ES6脚本,也可以直接在网页中放置ES6代码。
|
||||||
|
|
||||||
```javascript
|
```javascript
|
||||||
<script type="module">
|
<script type="module">
|
||||||
@ -501,15 +501,34 @@ Traceur允许将ES6代码直接插入网页。首先,必须在网页头部加
|
|||||||
|
|
||||||
正常情况下,上面代码会在控制台打印出9。
|
正常情况下,上面代码会在控制台打印出9。
|
||||||
|
|
||||||
注意,`script`标签的`type`属性的值是`module`,而不是`text/javascript`。这是Traceur编译器识别ES6代码的标识,编译器会自动将所有`type=module`的代码编译为ES5,然后再交给浏览器执行。
|
如果想对Traceur的行为有精确控制,可以采用下面参数配置的写法。
|
||||||
|
|
||||||
如果ES6代码是一个外部文件,也可以用`script`标签插入网页。
|
|
||||||
|
|
||||||
```javascript
|
```javascript
|
||||||
<script type="module" src="calc.js" >
|
<script>
|
||||||
|
// Create the System object
|
||||||
|
window.System = new traceur.runtime.BrowserTraceurLoader();
|
||||||
|
// Set some experimental options
|
||||||
|
var metadata = {
|
||||||
|
traceurOptions: {
|
||||||
|
experimental: true,
|
||||||
|
properTailCalls: true,
|
||||||
|
symbols: true,
|
||||||
|
arrayComprehension: true,
|
||||||
|
asyncFunctions: true,
|
||||||
|
asyncGenerators: exponentiation,
|
||||||
|
forOn: true,
|
||||||
|
generatorComprehension: true
|
||||||
|
}
|
||||||
|
};
|
||||||
|
// Load your module
|
||||||
|
System.import('./myModule.js', {metadata: metadata}).catch(function(ex) {
|
||||||
|
console.error('Import failed', ex.stack || ex);
|
||||||
|
});
|
||||||
</script>
|
</script>
|
||||||
```
|
```
|
||||||
|
|
||||||
|
上面代码中,首先生成Traceur的全局对象`window.System`,然后`System.import`方法可以用来加载ES6模块。加载的时候,需要传入一个配置对象`metadata`,该对象的`traceurOptions`属性可以配置支持ES6功能。如果设为`experimental: true`,就表示除了ES6以外,还支持一些实验性的新功能。
|
||||||
|
|
||||||
### 在线转换
|
### 在线转换
|
||||||
|
|
||||||
Traceur也提供一个[在线编译器](http://google.github.io/traceur-compiler/demo/repl.html),可以在线将ES6代码转为ES5代码。转换后的代码,可以直接作为ES5代码插入网页运行。
|
Traceur也提供一个[在线编译器](http://google.github.io/traceur-compiler/demo/repl.html),可以在线将ES6代码转为ES5代码。转换后的代码,可以直接作为ES5代码插入网页运行。
|
||||||
@ -517,13 +536,9 @@ Traceur也提供一个[在线编译器](http://google.github.io/traceur-compiler
|
|||||||
上面的例子转为ES5代码运行,就是下面这个样子。
|
上面的例子转为ES5代码运行,就是下面这个样子。
|
||||||
|
|
||||||
```javascript
|
```javascript
|
||||||
<script src="http://google.github.io/traceur-compiler/bin/traceur.js"
|
<script src="https://google.github.io/traceur-compiler/bin/traceur.js"></script>
|
||||||
type="text/javascript"></script>
|
<script src="https://google.github.io/traceur-compiler/bin/BrowserSystem.js"></script>
|
||||||
<script src="http://google.github.io/traceur-compiler/src/bootstrap.js"
|
<script src="https://google.github.io/traceur-compiler/src/bootstrap.js"></script>
|
||||||
type="text/javascript"></script>
|
|
||||||
<script>
|
|
||||||
traceur.options.experimental = true;
|
|
||||||
</script>
|
|
||||||
<script>
|
<script>
|
||||||
$traceurRuntime.ModuleStore.getAnonymousModule(function() {
|
$traceurRuntime.ModuleStore.getAnonymousModule(function() {
|
||||||
"use strict";
|
"use strict";
|
||||||
@ -545,15 +560,15 @@ $traceurRuntime.ModuleStore.getAnonymousModule(function() {
|
|||||||
|
|
||||||
### 命令行转换
|
### 命令行转换
|
||||||
|
|
||||||
作为命令行工具使用时,Traceur是一个Node.js的模块,首先需要用npm安装。
|
作为命令行工具使用时,Traceur是一个Node的模块,首先需要用Npm安装。
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
$ npm install -g traceur
|
$ npm install -g traceur
|
||||||
```
|
```
|
||||||
|
|
||||||
安装成功后,就可以在命令行下使用traceur了。
|
安装成功后,就可以在命令行下使用Traceur了。
|
||||||
|
|
||||||
traceur直接运行es6脚本文件,会在标准输出显示运行结果,以前面的`calc.js`为例。
|
Traceur直接运行es6脚本文件,会在标准输出显示运行结果,以前面的`calc.js`为例。
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
$ traceur calc.js
|
$ traceur calc.js
|
||||||
@ -561,7 +576,7 @@ Calc constructor
|
|||||||
9
|
9
|
||||||
```
|
```
|
||||||
|
|
||||||
如果要将ES6脚本转为ES5保存,要采用下面的写法
|
如果要将ES6脚本转为ES5保存,要采用下面的写法。
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
$ traceur --script calc.es6.js --out calc.es5.js
|
$ traceur --script calc.es6.js --out calc.es5.js
|
||||||
@ -575,7 +590,7 @@ $ traceur --script calc.es6.js --out calc.es5.js
|
|||||||
$ traceur --script calc.es6.js --out calc.es5.js --experimental
|
$ traceur --script calc.es6.js --out calc.es5.js --experimental
|
||||||
```
|
```
|
||||||
|
|
||||||
命令行下转换的文件,就可以放到浏览器中运行。
|
命令行下转换生成的文件,就可以直接放到浏览器中运行。
|
||||||
|
|
||||||
### Node.js环境的用法
|
### Node.js环境的用法
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user