JavaScript继承

         面向对象编程一直是我们编程的重点,它将数据和代码有机的结合,使编程的思想更加简单化和逻辑化。但JavaScript却不是一门完全的编程语言,它只是一门基本面向对象的编程语言,在JavaScript中没有"类"的概念,只有对象和函数。但JavaScript也有面向对象的基本特征----继承、封装、多态

         继承主要是指父类与子类之间的逻辑关系,子类可以从父类那继承方法、属性,其实这和现实的生活是完全吻合的。

           JavaScript继承实现一:

function Person(name,food){
     this.name=name;
     this.eat=function(){
     alert(name+" eat "+food);
     }
 }
 function Boy(food){
     Person.call(this,"boy",food);//调用父类的构造方法
 }
 function Girl(food){
     Person.call(this,"girl",food);//调用父类的构造方法
 }
 var b=new Boy("fish");
 var g=new Girl("pig");
 //alert(boy.constructor==girl.constructor);//false
 b.eat();//fish
 g.eat();//pig
 alert(b.name);//boy
 alert(g.name);//girl

 

 

    JavaScript继承实现二:

function Animal(){
  this.name="animal";
  /*this.eat=function(){
   alert("eat");
  }*/
 }
 //通过prototype给Animal对象动态添加方法
 Animal.prototype.eat=function(food){
  alert("eat "+food);
 }
 //子类Dog
 function Dog(){
  
 }
 Dog.prototype=new Animal();//通过prototype(原型),建一个基类的对象作为子类原型的原型
 var d=new Dog();
 d.eat("骨头");
 
 //另一个子类Snake
 function Snake(){
  
 }
 Snake.prototype=new Animal();//通过prototype(原型),建一个基类的对象作为子类原型的原型
 var s=new Snake();
 s.eat("------");

 s.show=function(){
  alert("show");
 }
 s.show();
 var a=new Animal();
 a.show();//错误,父类是不能调用子类方法的

 

 

 说明:JavaScript 的所有function 类型的对象都有一个prototype 属性。这个prototype 属性本身又是一
个object 类型的对象,因此我们也可以给这个prototype 对象添加任意的属性和方法。既然prototype
是对象的“原型”,那么由该函数构造出来的对象应该都会具有这个“原型”的特性。事实上,在构造函数的p
rototype 上定义的所有属性和方法,都是可以通过其构造的对象直接访问和调用的。也可以这么说,pro
totype 提供了一群同类对象共享属性和方法的机制。

 

 在原型模型中,为了实现类继承,必须首先将子类构造函数的prototype 设置为一个父类的对象实例。
创建这个父类对象实例的目的就是为了构成原型链,以起到共享上层原型方法作用。

 

 在javascript中,所有的方法都有一个call方法和apply方法.这两个方法可以模拟对象调用方法.它的第一个参数是对象,后面的
参数表示对象调用这个方法时的参数

 

你可能感兴趣的:(JavaScript,编程,生活,prototype,D语言)