js 原型继承 Prototype

本文介绍JavaScript中构造函数如何继承另一个对象的属性和方法,并通过示例详细解释了继承的注意事项,包括同名成员的覆盖、单一成员与对象的先后继承顺序及多对象继承等问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

javascript 中,(构造)函数可以继承另外一个对象。


1、构造函数实例化出来的对象除了本身成员外,还会拥有被继承对象的成员。

关键字:prototype

例:

var cat={name:"windy",climb:function(){console.log("可以爬树")}};   //对象cat

var tiger=function(){                  //构造函数 tiger
this.color="white";
this.hobby=function(){console.log("喜欢吃肉")};
}

tiger.prototype=cat   //构造函数tiger继承cat
var northTiger=new tiger();
console.log(northTiger);  //打印如下:


2、继承单一成员


var tiger=function(){
this.color="white";
this.hobby=function(){console.log("喜欢吃肉")};
}

tiger.prototype.weight=100;   //继承单一成员变量
tiger.prototype.cry=function(){console.log("会嚎叫")}; //继承单一成员方法

var northTiger=new tiger();
console.log(northTiger);//打印如下:



3、继承的注意事项:

a、本身和继承对象拥有同名的成员,要使用本身成员

b、单一成员和对象同时继承时,需要先继承对象再继承单一成员,不然无法继承到单一成员

c、同时继承多个对象,后者覆盖前者


b:例子1  先继承单一成员再继承对象

var cat={name:"windy"};
var tiger=function(){
this.color="white";
this.hobby=function(){console.log("喜欢吃肉")};
}

tiger.prototype.weight=100;   //继承单一成员变量
tiger.prototype.cry=function(){console.log("会嚎叫")}; //继承单一成员方法
tiger.prototype=cat;  //继承对象cat
var northTiger=new tiger();
console.log(northTiger);//打印如下:


可以看到,如下两个属性没有被继承,只继承了cat对象的name

tiger.prototype.cry=function(){console.log("会嚎叫")}; //继承单一成员方法
tiger.prototype=cat;  //继承对象cat


b、例子2   先继承对象再继承单一成员

var cat={name:"windy",sex:"man"};
var tiger=function(){
this.color="white";
this.hobby=function(){console.log("喜欢吃肉")};
}

tiger.prototype=cat;  //继承对象
tiger.prototype.name="justin";   //继承单一成员变量
tiger.prototype.cry=function(){console.log("会嚎叫")}; //继承单一成员方法
var northTiger=new tiger();
console.log(northTiger); 打印如下:


可以看到tiger继承了单一成员也继承了对象。因为先继承了对象,再继承了单一成员,对象的name与单一成员的nane属性相同,单一成员的name

覆盖了继承的对象的name











评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值