深入学习原型继承概念

<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>Document</title>
</head>
<body>
	<script>
		// js中怎么实现继承:通过原型链的概念

		// 构造函数  原型对象  实例对象 三者之间的关系
		/*
		 1.构造函数.prototype = 原型对象
		 2.原型对象.constructor = 构造函数(模板)
		 3.原型对象.isPrototypeOf(实例对象)  判断实例对象的原型是不是  当前对象
		 4.构造函数 和  实例对象 (类和实例)
		*/

		// 父类 构造函数 sup

		function Sup(name){
        	this.name = name;
		}

		// 父类原型对象
		Sup.prototype = {
			constructor:Sup,
			sayName:function(){
				alert(this.name)
			}
		}
		// 子类构造函数
		function Son(age){
			this.age = age;
		}

		// 如果我们让子类的原型对象变为父类的实例化对象 将会发生什么?
		/*
			1.此时的原型对象包含一个指向另一个原型的指针
			Sup 的实例对象 和 原型对象有一个 isPrototypeOf 的关系
			2.相应的另一个原型中也包含着指向另一个构造函数的指针
			子类的原型对象的构造器(模板)变成了父类的构造器

			以此实现继承
		*/
		// alert(Son.prototype.constructor)
		Son.prototype = new Sup("小张");
		// alert(Son.prototype.constructor)
		var son1 = new Son();
		alert(son1.name)//实现继承
		son1.sayName();


	</script>
</body>
</html>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值