时间:2021-05-26
一:js原型继承四步曲
//js模拟类的创建以及继承 //动物(Animal),有头这个属性,eat方法 //名字这个属性 //猫有名字属性,继承Animal,抓老鼠方法 //第一步:创建父类 function Animal(name){ this.name = name; } //给父类添加属性方法 Animal.prototype.eat = function(){ console.log(this.name + " eating..."); } //第二步:创建子类 function Cat(name){ Animal.call(this,name); } //第三步:确定继承的关系 Cat.prototype = Object.create(Animal.prototype); //第四步:改造构造器 //改变了某个构造器的原型之后,紧接着的代码一定是改构造器 Cat.prototype.constructor = Cat; Cat.prototype.zhualaoshu = function(){ console.log(this.name + " 抓 老鼠"); } var mao = new Cat("猫"); mao.eat(); mao.zhualaoshu();二:原型继承图
下图辅助理解
练习提巩固理解、
函数Foo的__proto的值等于Foo.prototype,对吗? 不对 Object的prototype可以修改吗?能与不能原因是什么 不可以 顶级constructor是谁? Function() 顶级原型对象是谁? Object.prototype 对象的construtor成员是个属性还是个方法? 方法 Function有没有__proto__,为什么?值等于Object.prototype吗? 有,是Function.prototype; 所有的构造器的__proto__都等于其对应的prototype 不对 创建类形式的继承的四部曲是什么? 创建父类——>创建子类——>确定继承关系——>改构造器 Function的constructor与prototype值可以修改吗? 可以 Object.prototype === Object.__proto__吗? 不对 Function.prototype === Function.__proto__吗? 是 function F(){}; var f1 = new F();f1.__proto__ === Object.prototype吗? 不对
以上这篇JS原型继承四步曲及原型继承图一览就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
温馨提示:想要更好的理解JS继承方式,须了解构造函数、原型对象、实例化对象、原型链等概念第一种:原型链继承利用原型链的特点进行继承functionParent(
原型链继承原型链继承是ECMAScript的主要继承方式。其基本思想就是通过原型继承多个引用类型的属性和方法。什么是原型链?每个构造函数都会有一个原型对
本文实例讲述了JS实现继承的几种常用方式。分享给大家供大家参考,具体如下:1,原型链继承原型链继承/***优点:*实例是父类的实例也是子类的实例*父类新增原型方
JavaScript中的继承比较奇葩,无法实现接口继承,只能依靠原型继承。原型链原型就是一个对象,通过构造函数创建出来的实例会有指针指向原型得到原型的属性和方法
整理《javascript高级程序设计》中继承的方法以及优缺点。1.原型链ECMAScript中描述了原型链的概念,并将原型链作为实现继承的主要方法。原型链继承