js原型和原型链继承

继承

通俗来说,就是子类能够继承父类构造函数及原型对象上的属性和方法。那么怎么实现继承呢?

1. 原型继承

实现原理:因为实例对象上有构造函数和他的原型对象上的所有属性和方法,被所有实例共享
代码实现
父类为 Person,子类为Student

function Person() {
     this.name = '小明';
     this.has = ['车', '房'];
   }
   Person.prototype.getName = function () {
     console.log("我的名字是:" + this.name);
   }

   function Student() {
     this.major = "English";
   }
   Student.prototype = new Person();
   Student.prototype.constructor = Student;
   // 以下测试代码
   var student1 = new Student();
   student1.has.push("存款"); //s99行
   console.log(student1)

原型继承带来的问题:

  • 不能传参给父类
  • 父类属性是引用类型, 会被子类篡改
    这里 s99 行给子类 Student 的 has 属性增加了一个“存款”,父类Person的has属性也改了。

2. 构造函数继承

实现原理:在子类构造函数中直接调用父类构造函数
代码实现
父类为 Person,子类为Student,以下几种实现方法同上。

function Person(args) {
     this.name = '小明';
     this.has = ['车', '房'];
   }
   Person.prototype.getName = function () {
     console.log("我的名字是:" + this.name);
   }

   function Student(args) {
     Person.call(this,args) //调用父类构造函数,并修改this指向为Student
     this.major = "English"; //这里涉及原型链继承会先找自己身上有没有该属性,找不到再沿着原型链向上找。所以子类自己属性放在上一行代码的下面。如果有同名属性,覆盖上级
   }
   // 以下测试代码
   var student1 = new Student('学生1');
   student1.has.push("存款");
   console.log(student1)

构造函数继承解决了原型继承的问题,但也有不足:

  • 不能继承父类原型对象 prototype 上的方法

3. 组合式继承

实现原理:将以上两种方法组合起来使用
代码实现

function Person(args) {
     this.name = '小明';
     this.has = ['车', '房'];
   }
   Person.prototype.getName = function () {
     console.log("我的名字是:" + this.name);
   }

   function Student(args) {
     Person.call(this,args)
     this.major = "English";
   }

   Student.prototype = new Person();
   Student.prototype.constructor = Student;
   // 以下测试代码
   var student1 = new Student('学生1');
   student1.has.push("存款");
   console.log(student1)

问题:父类构造函数被执行了两次

3. 寄生组合式继承

实现原理:在组合式继承的基础上,使用Object.create创建空对象,并实现继承。

A = Object.create( B ) 会创建一个新对象,并使 A 的原型,指向 B
A.__proto__ === B

代码实现

function Person(args) {
     this.name = '小明';
     this.has = ['车', '房'];
   }
   Person.prototype.getName = function () {
     console.log("我的名字是:" + this.name);
   }

   function Student(args) {
     Person.call(this,args)
     this.major = "English";
   }
   
   Student.prototype = Object.create(Person.prototype); 
   Student.prototype.constructor = Student;
   // 以下测试代码
   var student1 = new Student('学生1');
   student1.has.push("存款");
   console.log(student1)

原型链图示

原型链示例

  • 4
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我来回答你的问题。以下是一些JS原型继承原型链的面试题及其答案: 1. 什么是原型继承? 答:原型继承是通过将一个对象的原型作为另一个对象的原型来实现继承。在JS中,每个对象都有一个原型,它可以通过__proto__属性来访问。 2. 什么是原型链? 答:原型链是一种通过原型继承来实现对象间继承关系的机制。当我们访问一个对象的属性时,JS会首先在该对象自身查找,如果没有找到,就会在它的原型对象上查找,如果还没有找到,就会在原型对象的原型对象上查找,一直到Object.prototype对象为止,这个查找的过程就是原型链。 3. 如何实现一个简单的原型继承? 答: ```javascript function Person(name) { this.name = name; } Person.prototype.sayHi = function() { console.log('Hi, my name is ' + this.name); } function Student(name, grade) { Person.call(this, name); this.grade = grade; } Student.prototype = Object.create(Person.prototype); Student.prototype.constructor = Student; Student.prototype.sayGrade = function() { console.log('My grade is ' + this.grade); } var tom = new Student('Tom', 3); tom.sayHi(); tom.sayGrade(); ``` 4. 如何判断一个对象是否是另一个对象的实例? 答:可以使用instanceof运算符来判断,例如: ```javascript var obj = {}; console.log(obj instanceof Object); // true ``` 5. 如何判断一个属性是在对象自身定义的还是继承原型? 答:可以使用JS提供的hasOwnProperty方法来判断,例如: ```javascript var obj = {}; console.log(obj.hasOwnProperty('toString')); // false console.log(Object.prototype.hasOwnProperty('toString')); // true ``` 希望这些问题和答案能够帮助你更好地理解JS原型继承原型链

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值