diff --git a/docs/async.md b/docs/async.md
index 7136986..afca50d 100644
--- a/docs/async.md
+++ b/docs/async.md
@@ -750,10 +750,22 @@ var result = asyncReadFile();
(4)返回值是Promise。`async`函数的返回值是Promise对象,这比Generator函数的返回值是Iterator对象方便多了。你可以用`then`方法指定下一步的操作。
-进一步说,async函数完全可以看作多个异步操作,包装成的一个Promise对象,而`await`命令就是内部`then`命令的语法糖。
+进一步说,`async`函数完全可以看作多个异步操作,包装成的一个Promise对象,而`await`命令就是内部`then`命令的语法糖。
正常情况下,`await`命令后面是一个Promise对象,否则会被转成Promise。
+下面是一个完整的例子。
+
+```javascript
+async function getTitle(url) {
+ let response = await fetch(url);
+ let html = await response.text();
+ return html.match(/
([\s\S]+)<\/title>/i)[1];
+}
+getTitle('https://tc39.github.io/ecma262/').then(console.log)
+// "ECMAScript 2017 Language Specification"
+```
+
### async函数的实现
async 函数的实现,就是将 Generator 函数和自动执行器,包装在一个函数里。
diff --git a/docs/string.md b/docs/string.md
index 48a29a0..0bd9067 100644
--- a/docs/string.md
+++ b/docs/string.md
@@ -468,7 +468,40 @@ var msg = `Hello, ${place}`;
// "Hello World"
```
-如果需要引用模板字符串本身,可以像下面这样写。
+模板字符串甚至还能嵌套。
+
+```javascript
+const tmpl = addrs => `
+
+ ${addrs.map(addr => `
+ ${addr.first} |
+ ${addr.last} |
+ `).join('')}
+
+`;
+```
+
+上面代码中,模板字符串的变量之中,又嵌入了另一个模板字符串,使用方法如下。
+
+```javascript
+const data = [
+ { first: '', last: 'Bond' },
+ { first: 'Lars', last: '' },
+];
+
+console.log(tmpl(data));
+//
+//
+// |
+// Bond |
+//
+// Lars |
+// |
+//
+//
+```
+
+如果需要引用模板字符串本身,在需要时执行,可以像下面这样写。
```javascript
// 写法一
@@ -590,6 +623,12 @@ div.innerHTML = parse({ supplies: [ "broom", "mop", "cleaner" ] });
模板字符串的功能,不仅仅是上面这些。它可以紧跟在一个函数名后面,该函数将被调用来处理这个模板字符串。这被称为“标签模板”功能(tagged template)。
+```javascript
+alert`123`
+// 等同于
+alert(123)
+```
+
标签模板其实不是模板,而是函数调用的一种特殊形式。“标签”指的就是函数,紧跟在后面的模板字符串就是它的参数。
```javascript
@@ -663,7 +702,7 @@ var total = 30;
var msg = passthru`The total is ${total} (${total*1.05} with tax)`;
function passthru(literals) {
- var result = "";
+ var result = '';
var i = 0;
while (i < literals.length) {