class, extends, super
来源:互联网 发布:人生 不 快乐 知乎 编辑:程序博客网 时间:2024/06/04 18:56
这三个特性涉及了ES5中最令人头疼的的几个部分:原型、构造函数,继承…你还在为它们复杂难懂的语法而烦恼吗?你还在为指针到底指向哪里而纠结万分吗?
有了ES6我们不再烦恼!
ES6提供了更接近传统语言的写法,引入了Class(类)这个概念。新的class写法让对象原型的写法更加清晰、更像面向对象编程的语法,也更加通俗易懂。
class Animal { constructor(){ this.type = 'animal' } says(say){ console.log(this.type + ' says ' + say) }}let animal = new Animal()animal.says('hello') //animal says helloclass Cat extends Animal { constructor(){ super() this.type = 'cat' }}let cat = new Cat()cat.says('hello') //cat says hello
上面代码首先用class定义了一个“类”,可以看到里面有一个constructor方法,这就是构造方法,而this关键字则代表实例对象。简单地说,constructor内定义的方法和属性是实例对象自己的,而constructor外定义的方法和属性则是所有实例对象可以共享的。
Class之间可以通过extends关键字实现继承,这比ES5的通过修改原型链实现继承,要清晰和方便很多。上面定义了一个Cat类,该类通过extends关键字,继承了Animal类的所有属性和方法。
super关键字,它指代父类的实例(即父类的this对象)。子类必须在constructor方法中调用super方法,否则新建实例时会报错。这是因为子类没有自己的this对象,而是继承父类的this对象,然后对其进行加工。如果不调用super方法,子类就得不到this对象。
ES6的继承机制,实质是先创造父类的实例对象this(所以必须先调用super方法),然后再用子类的构造函数修改this。
阅读全文
0 0
- class、extends、super
- class, extends, super
- java super extends
- java super vs extends
- 泛型 extends 和 super
- <? extends AnyClass> <? super AnyClass>
- ES6学习记录之class, extends, super和箭头函数与this
- java generic super/extends (java 泛型中的super/extends)
- 泛型中extends和super差别
- java关键字this、extends、super
- Java泛型 <? extends ...>与<? super ...>
- Java 泛型extends和super
- ? extends T 与 ? super T
- java泛型 extends与super
- JAVA泛型extends和super
- <? extends T>和<? super T>
- implement, extends, super in Java
- class servJump extends HttpServlet
- 文章标题
- leetcode537. Complex Number Multiplication
- 设计模式–策略模式
- 孙鑫VC++学习:对话框-ONE
- 设计模式之观察者模式
- class, extends, super
- Spring Cloud构建微服务架构(五)服务网关
- dict语法 --鱼c工作室笔记
- poj 3253
- 高通平台中简单了解DTB
- 【人工智能】图像识别之小白天书——验证码篇(3)
- ARP协议【地址解析协议】
- ELK 日志分析系统(二)
- php 处理文件