JavaScript是如何实现继承的

  最近最网上看了一我的面试淘宝时的经历,而后发现了本身有好多好多不太清楚的地方,因此特此写点文章来加深本身对一些问题的理解。javascript

  文章中提到了一个问题是:JavaScript是如何实现继承的?前端

 

 下面我便阐述一些在网上找到的方法和实例来解释下,借以加深本身的印象。java

  咱们知道JavaScript中的function是万能的,除了用于的函数定义,也能够用于类的定义。面试

  JavaScript的继承,提及来也是有点怪,不像C++和一些面向对象的语言,他没有public,private等访问控制修饰,也没有implement或其余特定的符号来讲明是实现继承。函数

  关于javascript类的继承能够参考一下下面的这个例子。this

 1 <script type="text/javascript"> 
 2 function Person() {
 3     // 属性 
 4     this.Gender = "female";
 5     this.Age = 18;
 6     this.Words = "Silence";
 7     // 方法
 8     this.shouting = function() {
 9         alert("开心哦!父类的方法");
10     }
11 }
12 // 继承
13 function Programmer() {
14     this.base = Person;
15 }
16 Programmer.prototype = new Person;
17 // 为子类添加新的方法
18 Programmer.prototype.typeCode = function() {
19     alert("俺是敲代码的!IT民工,很不开心。子类的方法");
20 }
21 // 调用示例
22 function sayHello() {
23     var a = new Programmer();
24     alert(a.Gender); // 调用父类的属性
25     a.shouting(); // 调用父类的方法
26     a.typeCode(); // 调用子类的方法
27 }        
28 sayHello();
29 </script>

  上例中,首先是声明一个person类,里面包含了一些属性和方法,而后接着又声明了一个programmer类,其中有个base属性,这个属性并非必需的,可是出于规范以及之后在查找对象所继承的类时都须要写上,而后是给programmer的原型对象(prototype)拷贝了person类;因而便实现了类的继承。spa

模拟JavaScript中类和继承的一些原理

  在面向对象的语言中,咱们使用类来建立一个自定义对象。然而JavaScript中全部事物都是对象,那么用什么办法来建立自定义对象呢?prototype

这就须要引入另一个概念 - 原型(prototype),咱们能够简单的把prototype看作是一个模版,新建立的自定义对象都是这个模版(prototype)的一个拷贝 (实际上不是拷贝而是连接,只不过这种连接是不可见,给人们的感受好像是拷贝)。code

  让咱们看一下经过prototype建立自定义对象的一个例子: 对象

 1 // 构造函数
 2   function Person(name, sex) {
 3       this.name = name;
 4       this.sex = sex;
 5   }
 6   // 定义Person的原型,原型中的属性能够被自定义对象引用
 7   Person.prototype = {
 8       getName: function() {
 9           return this.name;
10       },
11       getSex: function() {
12           return this.sex;
13       }
14   }

  这里咱们把函数Person称为构造函数,也就是建立自定义对象的函数。能够看出,JavaScript经过构造函数和原型的方式模拟实现了类的功能。

  下面经过一个例子来具体阐述建立一个自定义对象,javascript所作的具体的工做

1 var zhang = new Person("ZhangSan", "man");
2 console.log(zhang.getName()); // "ZhangSan"
3 var chun = new Person("ChunHua", "woman");
4 console.log(chun.getName()); // "ChunHua"

  当代码var zhang = new Person("ZhangSan", "man")执行时,其实内部作了以下几件事情:

  1. 建立一个空白对象(new Object())。
  2. 拷贝Person.prototype中的属性(键值对)到这个空对象中(咱们前面提到,内部实现时不是拷贝而是一个隐藏的连接)。
  3. 将这个对象经过this关键字传递到构造函数中并执行构造函数。
  4. 将这个对象赋值给变量zhang。
  5. 全部工做完成。

  为了证实prototype模版并非被拷贝到实例化的对象中,而是一种连接的方式,请看以下代码:

 1 function Person(name, sex) {
 2     this.name = name;
 3     this.sex = sex;
 4 }
 5 Person.prototype.age = 20;
 6 var zhang = new Person("ZhangSan", "man");
 7 console.log(zhang.age); // 20
 8 // 覆盖prototype中的age属性
 9 zhang.age = 19;
10 console.log(zhang.age); // 19
11 delete zhang.age;
12 // 在删除实例属性age后,此属性值又从prototype中获取
13 console.log(zhang.age); // 20

  在上面的这个例子中,若是他仅仅是经过拷贝得来的,则在删除了这个age这个属性后,这个对象里面将不会存在,可是例子中的age属性还能输出,仍是覆盖之前的值,说明咱们仅仅是删除了子类中同名的属性,而父类当中的age属性经过一种不可见的连接依然存在在对象中。

如何在JavaScript中实现简单的继承?

  下面的例子将建立一个雇员类Employee,它从Person继承了原型prototype中的全部属性。

 1 function Employee(name, sex, employeeID) {
 2     this.name = name;
 3     this.sex = sex;
 4     this.employeeID = employeeID;
 5 }
 6 // 将Employee的原型指向Person的一个实例
 7 // 由于Person的实例能够调用Person原型中的方法, 因此Employee的实例也能够调用Person原型中的全部属性。
 8 Employee.prototype = new Person();
 9 Employee.prototype.getEmployeeID = function() {
10     return this.employeeID;
11 };
12 var zhang = new Employee("ZhangSan", "man", "1234");
13 console.log(zhang.getName()); // "ZhangSan

  好了,以上就是一些关于javascript实现继承的具体过程,和实现继承的方法。

  固然总结一下,javascript中的继承机制仅仅是靠模拟的,于一些面向对象的语言来说,显的粗糙并且还有一些缺陷,不过总的来说,这依然不并会下降前端开发者在这方面的热情。

  

  最后,第一次发博客,不免存在一些不足的地方,忘各位指正与见谅。

  另外推广下我的小站:www.xiangyifight.com

相关文章
相关标签/搜索