diff --git a/docs/decorator.md b/docs/decorator.md index 7e1abac..e6f9435 100644 --- a/docs/decorator.md +++ b/docs/decorator.md @@ -413,7 +413,7 @@ Trait也是一种修饰器,功能与Mixin类型,但是提供更多功能, 下面采用[traits-decorator](https://github.com/CocktailJS/traits-decorator)这个第三方模块作为例子。这个模块提供的traits修饰器,不仅可以接受对象,还可以接受ES6类作为参数。 ```javascript -import {traits } from 'traits-decorator' +import { traits } from 'traits-decorator' class TFoo { foo() { console.log('foo') } diff --git a/docs/function.md b/docs/function.md index e830d42..9cf38e6 100644 --- a/docs/function.md +++ b/docs/function.md @@ -427,7 +427,6 @@ Generator函数运行后,返回一个遍历器对象,因此也可以使用 ```javascript - var go = function*(){ yield 1; yield 2; @@ -435,13 +434,14 @@ var go = function*(){ }; [...go()] // [1, 2, 3] - ``` 上面代码中,变量go是一个Generator函数,执行后返回的是一个遍历器,对这个遍历器执行扩展运算符,就会将内部遍历得到的值,转为一个数组。 ## 箭头函数 +### 基本用法 + ES6允许使用“箭头”(=>)定义函数。 ```javascript @@ -540,13 +540,19 @@ headAndTail(1, 2, 3, 4, 5) // [1,[2,3,4,5]] ``` +### 使用注意点 + 箭头函数有几个使用注意点。 -- 函数体内的this对象,绑定定义时所在的对象,而不是使用时所在的对象。 -- 不可以当作构造函数,也就是说,不可以使用new命令,否则会抛出一个错误。 -- 不可以使用arguments对象,该对象在函数体内不存在。 +(1)函数体内的this对象,绑定定义时所在的对象,而不是使用时所在的对象。 -上面三点中,第一点尤其值得注意。this对象的指向是可变的,但是在箭头函数中,它是固定的。下面的代码是一个例子,将this对象绑定定义时所在的对象。 +(2)不可以当作构造函数,也就是说,不可以使用new命令,否则会抛出一个错误。 + +(3)不可以使用arguments对象,该对象在函数体内不存在。如果要用,可以用Rest参数代替。 + +(4)不可以使用yield命令,因此箭头函数不能用作Generator函数。 + +上面四点中,第一点尤其值得注意。this对象的指向是可变的,但是在箭头函数中,它是固定的。下面的代码是一个例子,将this对象绑定定义时所在的对象。 ```javascript var handler = { @@ -569,6 +575,8 @@ var handler = { 长期以来,JavaScript语言的this对象一直是一个令人头痛的问题,在对象方法中使用this,必须非常小心。箭头函数绑定this,很大程度上解决了这个困扰。 +### 嵌套的箭头函数 + 箭头函数内部,还可以再使用箭头函数。下面是一个ES5语法的多重嵌套函数。 ```javascript diff --git a/docs/style.md b/docs/style.md index e43db80..5f02430 100644 --- a/docs/style.md +++ b/docs/style.md @@ -1,6 +1,6 @@ # 编程风格 -本章探讨如何将ES6的新语法,运用到编码实践之中,与传统的JavaScript语法结合在一起,写出合理的、易于阅读和维护的代码。多家公司和组织已经公开了它们的风格规范,具体可参阅[jscs.info](http://jscs.info/),下面的内容主要参考了[Airbnb](http://jscs.info/)的JavaScript风格规范。 +本章探讨如何将ES6的新语法,运用到编码实践之中,与传统的JavaScript语法结合在一起,写出合理的、易于阅读和维护的代码。多家公司和组织已经公开了它们的风格规范,具体可参阅[jscs.info](http://jscs.info/),下面的内容主要参考了[Airbnb](https://github.com/airbnb/javascript)的JavaScript风格规范。 ## 块级作用域