Rest Parameter, Spread Oprator, Arrow Func
- Rest Parameter
假设有一个方法,我们希望可以这样调用它:
data:image/s3,"s3://crabby-images/2d98e/2d98eeb68d99e14913cc9bb6e3c6b6316d9819f2" alt=""
如果使用es5的方法,我们可能会这样实现它:
data:image/s3,"s3://crabby-images/3d336/3d33668e455027963b73606e4d75a2ecbad628ba" alt=""
这样写有两个问题:
- 让人误以为这个方法不接受参数
- 任何对方法签名的修改,都有可能会让代码崩溃。比如说,添加了一个参数:
data:image/s3,"s3://crabby-images/4d5af/4d5af74c326e52fe58a683ff756a96adb8ebcfe7" alt=""
解决:
rest parameter syntax
data:image/s3,"s3://crabby-images/4c191/4c191b0eb0d53a3d7c922f48f04ef5bd83e1b3f4" alt=""
三个点的语法可以把我们传进来的所有参数转换成一个数组。注意,rest parameter 必须是方法签名里的最后一个参数。
- spread oprator
假设我们的数据是从一个请求中返回来的,如下:
data:image/s3,"s3://crabby-images/a5545/a5545651968347a4c0ef846188d539f86f049833" alt=""
这里我们得到的tags是一个数组,而我们之前的displayTags方法接收的是一个个单独的参数,那怎么做呢?如下:
data:image/s3,"s3://crabby-images/66973/66973f7df804d53e6ec07df210f0ad44c8c1eb24" alt=""
data:image/s3,"s3://crabby-images/1863b/1863ba8ca1aa24ce3bfedb2c8a4fe28f0f4a5f1e" alt=""
在这里,这三个点成为spread operator. 它可以使一个数组对象拆分成一个个的单独的元素。这个语法和之前的rest Parameter里的一样,但这次它是用在方法调用中,而不是方法定义中。(注意两个语法一样,但作用不一样,取决于它用在什么地方)
data:image/s3,"s3://crabby-images/be3a1/be3a11156b7becd21f435ab8914ef82b53eb3138" alt=""
- arrow function
首先,我们对上面的功能做一个小封装:
data:image/s3,"s3://crabby-images/20a41/20a41818017ee16bf7979f8df85770ef1dc7b61e" alt=""
我们知道,红色线圈起来的这个this 在调用时会失败,因为它在回调函数里,这时函数的执行环境的this已经不是TagComponent对象了。
解决方法:
data:image/s3,"s3://crabby-images/21995/219959413fc587ef31c11b32a5719e6bab289d21" alt=""
箭头函数有词法作用域绑定作用,就是说他的作用域是取决于它被定义的地方,而不是运行时才决定的。如上,这个箭头函数就是定义在TagComponent对象中的。
Classes
ES5下,利用构造函数生成对象的方法。通过将方法添加到构造函数的prototype上来实现公用的目的。
data:image/s3,"s3://crabby-images/5e84e/5e84e4cb6e964f669dd9eea16b368ab1cae64bd4" alt=""
在ES2015中,我们可以使用新class的语法来写出更加简便的面向对象的Javascript 。(Using the New Class Syntax)
data:image/s3,"s3://crabby-images/9bf2f/9bf2f93bf1225d602ce23d108c8cbeb19862fea5" alt=""
注意,设置在constructor方法中的变量可以被class中的其他方法访问到。(Instance variables set on the constructor method can be accessed from all other instance method in the class)
data:image/s3,"s3://crabby-images/8a104/8a1044ddd80f7ccd197f2f441e50639c7ac51956" alt=""
注意,class的语法并不是引入了新的 JavaScript 对象模型,它只是基于目前存在的基于prototype实现继承方式的语法糖。它做的事情,实现的效果还是和之前的一模一样,只不过语法上改变了而已。(It's just the sweet way to write the same thing)
data:image/s3,"s3://crabby-images/f4ade/f4ade7da490f8aebe8b69bed832b789c563fff3c" alt=""
Class Inheritance
我们可以使用class的继承来减少代码重复。子类可以继承并指定定义在父类中的行为。extends关键字可以用来创建一个从其他类继承方法和属性的类。super方法可以运行父类里的constructor方法,基本上我们在每一个子类的constructor方法里第一行都会调用super()。子类也可以通过super对象来调用父类里的方法。
data:image/s3,"s3://crabby-images/21aeb/21aeb766b48c66a21ae53f328d6dda248e52fff6" alt=""
data:image/s3,"s3://crabby-images/f60cf/f60cf64d12b8e1f718482af02d7830fb62422fea" alt=""
网友评论