js中的prototype的解析

js的方法可以分为三种:对象方法、类方法、prototype方法

//对象方法
function People(name){
this.name=name;
this.introduct=function(){
alert("My name is"+this.name);
console.log("My name is"+this.name);
}
}

//类方法
People.Run=function(){
alert("I can run");
}
console.log(People.Run()); 
//原型方法
People.prototype.introduceChinese=function(){
alert("我的名字是"+this.name);
}

这里要注意类方法只能通过类名.方法名调用,实例方法只能通过实例名.方法名调用,反之不可以

还有prototype是类的属性,new出来的对象是没有这个属性的,比如People.prototype可以,var p=new People(); p.prototype不可以

function Aclass2(){
 this.property=2;
this.method=function(){
alert(2);
}  
}

function Aclass(){
this.property=1;
this.method=function(){
alert(1);
}
}

子类重写父类的属性和方法,要注意不能修改父类的属性和方法,可以这样写Aclass2.prototype=new Aclass();
把父类的一个实例对象赋值给子类的prototype属性,我们调用实例对象的时候,首先会调用构造函数的属性和方法,然后是
prototype中写的和父类的属性和方法

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值