上篇说过了关于原型链继承的问题,这篇详解一下。

1.开始:dog的实例属性(type:dog ),dog的原型对象(dog._proto_),

dog._proto_ :dog的原型对象属性(type:animals),animals的原型对象(animals._proto_),

animals._proto:animals的原型对象属性(a:a),object的原型对象(object._proto_),

object._proto:object的方法,null。

function animals(){
this.type = "animals";
}
animals.prototype.a = "a"; function dog(){
this.type = "dog";
} dog.prototype = new animals(); var d = new dog();
console.log(d);

2.在dog的构造函数中调用了animals,此时dog构造函数中会拷贝animals中的所有构造函数属性,若有相同的属性,则会修改为animals中的属性值。

开始:dog的实例属性(type:animals),dog的原型对象(dog._proto_),

dog._proto_ :dog的原型对象属性(type:animals),animals的原型对象(animals._proto_),

animals._proto:animals的原型对象属性(a:a),object的原型对象(object._proto_),

object._proto:object的方法,null。

function animals(){
this.type = "animals";
}
animals.prototype.a = "a"; function dog(){
this.type = "dog";
animals.call(this);
} dog.prototype = new animals(); var d = new dog();
console.log(d);

3.animals.call(this,type);此时传入了type参数,则在dog拷贝的实例属性type中值为传入的参数值,"animals",在animals中值仍为undefined。

开始:dog的实例属性(name:dog,type:animals),dog的原型对象(dog._proto_),

dog._proto_ :dog的原型对象属性(type:undefined),animals的原型对象(animals._proto_),

animals._proto:animals的原型对象属性(a:a),object的原型对象(object._proto_),

object._proto:object的方法,null。

function animals(type){
this.type = type;
}
animals.prototype.a = "a"; function dog(type){
this.name = "dog";
animals.call(this,type);
} dog.prototype = new animals(); var d = new dog("animals");
console.log(d);

4.开始:dog的实例属性(type:dog),dog的原型对象(dog._proto_),

dog._proto_ :dog的原型对象属性(b1:b1),object的原型对象(object._proto_),

object._proto:object的方法,null。

function animals(){
this.type = "animals";
}
animals.prototype.a = "a"; function dog(){
this.type = "dog";
}
dog.prototype.b1 = "b1"; var d = new dog();
console.log(d);

5.使用了原型继承,dog.prototype = new animals();,但此时在dog的原型对象属性中没有了b1:b1,那是因为在定义了dog.prototype.b1 = "b1"之后,又dog.prototype = new animals(),此时改变了dog原型对象指向,所以在它原来原型对象中存在的b1属性不再存在于新定义的dog原型对象中。

开始:dog的实例属性(type:dog),dog的原型对象(dog._proto_),

dog._proto_ :dog的原型对象属性(type:animals),animals的原型对象(animals._proto_),

animals._proto:animals的原型对象属性(a:a),object的原型对象(object._proto_),

object._proto:object的方法,null。

function animals(){
this.type = "animals";
}
animals.prototype.a = "a"; function dog(){
this.type = "dog";
}
dog.prototype.b1 = "b1"; dog.prototype = new animals(); var d = new dog();
console.log(d);

6.在dog.prototype = new animals();之前定义的dog.prototype.b1 = "b1"不在现在的dog原型对象属性中,在dog.prototype = new animals();之后定义的dog.prototype.b2 = "b2"存在于现在的dog原型对象属性中。

开始:dog的实例属性(type:dog),dog的原型对象(dog._proto_),

dog._proto_ :dog的原型对象属性(b2:b2,type:animals),animals的原型对象(animals._proto_),

animals._proto:animals的原型对象属性(a:a),object的原型对象(object._proto_),

object._proto:object的方法,null。

function animals(){
this.type = "animals";
}
animals.prototype.a = "a"; function dog(){
this.type = "dog";
}
dog.prototype.b1 = "b1"; dog.prototype = new animals();
dog.prototype.b2 = "b2"; var d = new dog();
console.log(d);

7.由于均是在dog.prototype = new animals();之后定义的,所以b1:b1,b2:b2均存在于dog的原型对象属性中。

开始:dog的实例属性(type:dog),dog的原型对象(dog._proto_),

dog._proto_ :dog的原型对象属性(b1:b1,b2:b2,type:animals),animals的原型对象(animals._proto_),

animals._proto:animals的原型对象属性(a:a),object的原型对象(object._proto_),

object._proto:object的方法,null。

function animals(){
this.type = "animals";
}
animals.prototype.a = "a"; function dog(){
this.type = "dog";
} dog.prototype = new animals();
dog.prototype.b2 = "b2";
dog.prototype.b1 = "b1"; var d = new dog();
console.log(d);

8.由于dog.prototype = new animals();改变了dog原型对象指代的构造函数,此时为animals构造函数,增加dog.prototype.constructor = dog;可以将构造函数修改为dog。

开始:dog的实例属性(type:dog),dog的原型对象(dog._proto_),

dog._proto_ :dog的原型对象属性(type:animals),animals的原型对象(animals._proto_),

animals._proto:animals的原型对象属性(a:a),object的原型对象(object._proto_),

object._proto:object的方法,null。

function animals(){
this.type = "animals";
}
animals.prototype.a = "a"; function dog(){
this.type = "dog";
} dog.prototype = new animals();
dog.prototype.constructor = dog; var d = new dog();
console.log(d);

js重点--原型链继承详解的更多相关文章

  1. 最详尽的 JS 原型与原型链终极详解,没有「可能是」。(一)

    最详尽的 JS 原型与原型链终极详解,没有「可能是」.(一) 第二篇已更新,点击进入第三篇已更新,点击进入

  2. 怎么理解js的原型链继承?

    前言 了解java等面向对象语言的童鞋应该知道.面向对象的三大特性就是:封装,继承,多态. 今天,我们就来聊一聊继承.但是,注意,我们现在说的是js的继承. 在js的es6语法出来之前,我们想实现js ...

  3. JS原型与原型链终极详解(转)

    JavaScript原型及原型链详解 一. 普通对象与函数对象 JavaScript 中,万物皆对象!但对象也是有区别的.分为普通对象和函数对象,Object,Function 是JS自带的函数对象. ...

  4. 【repost】JS原型与原型链终极详解

    一. 普通对象与函数对象  JavaScript 中,万物皆对象!但对象也是有区别的.分为普通对象和函数对象,Object ,Function 是JS自带的函数对象.下面举例说明 function f ...

  5. JS原型与原型链终极详解

    一. 普通对象与函数对象  JavaScript 中,万物皆对象!但对象也是有区别的.分为普通对象和函数对象,Object ,Function 是JS自带的函数对象.下面举例说明 function f ...

  6. JS 原型链图形详解

    JS原型链 这篇文章是「深入ECMA-262-3」系列的一个概览和摘要.每个部分都包含了对应章节的链接,所以你可以阅读它们以便对其有更深的理解. 对象 ECMAScript做为一个高度抽象的面向对象语 ...

  7. JS原型与原型链终极详解 (转载)

    这篇文章需要认认真真仔仔细细的看才能看懂 一. 普通对象与函数对象  JavaScript 中,万物皆对象!但对象也是有区别的.分为普通对象和函数对象,Object ,Function 是JS自带的函 ...

  8. 最详尽的 JS 原型与原型链终极详解(1)(2)(3)===转载

    转载===方便以后复习 原文网址:https://www.jianshu.com/p/dee9f8b14771 一. 普通对象与函数对象 JavaScript 中,万物皆对象!但对象也是有区别的.分为 ...

  9. [转] 最详尽的 JS 原型与原型链终极详解

    四. __proto__ JS 在创建对象(不论是普通对象还是函数对象)的时候,都有一个叫做__proto__ 的内置属性,用于指向创建它的构造函数的原型对象. 对象 person1 有一个 __pr ...

随机推荐

  1. Android Studio教程02-应用程序结构图及应用基础

    目录 1. Android应用程序开发技术结构图 2.Android的应用基础 2.1. Android的四大组件: 1. Android组件1: Activity 2. Android组件2: Se ...

  2. 链表倒数第k个节点

    1.一种较笨的办法是先将链表元素入栈,然后出栈找到倒数第k个节点值,再拿着值遍历链表去找到对于节点. 时间复杂度:O(n) (3n 遍历-出栈-遍历) 空间复杂度:O(n) (一个栈) 2.快慢指针, ...

  3. RabbitMQ for Mac OS Install

    使用brew来安装 RabbitMQ brew install rabbitmq 执行看到如下命令: Updating Homebrew... ==> Auto-updated Homebrew ...

  4. vue的生命周期的理解

    Vue实例有一个完整的生命周期,也就是从开始创建.初始化数据.编译模板.挂载Dom.渲染→更新→渲染.销毁等一系列过程,我们称这是Vue的生命周期.通俗说就是Vue实例从创建到销毁的过程,就是生命周期 ...

  5. 对css盒模型的理解

    介绍一下标准css的盒子模型?低版本IE的盒子模型有什么不同的? 1.有两种:IE盒子模型(怪异模式).W3c盒子模型(标准模式). 2.盒模型组成:内容(content).内边距(padding). ...

  6. Docker-通过docker-maven-plugin插件实现docker镜像构建并自动发布到远程docker服务器

    我们知道,docker能实现应用打包隔离,实现快速部署和迁移.如果我们开发应用使用了spring cloud + spring boot架构,那么,通过docker-maven-plugin实现快速构 ...

  7. 【视频】设计模式(Java)视频讲解

    设计模式(JAVA) 视频网址: http://www.qghkt.com/ 设计模式(JAVA)视频地址: https://ke.qq.com/course/318643?tuin=a508ea62 ...

  8. 使用Let's Encrypt生成免费SSL证书操作记录

    最近要做微信小程序,要求接口必须备案且是https,个人小站就直接准备使用免费的SSL证书,网上搜了一圈,发现Let's Encrypt是浏览器支持比较好的. 流程: 1. 首先去服务器上安装了Let ...

  9. storm ui 网页一直出现提示loading summary

    在更换了一次storm的版本之后:访问 http://mini1:8080/index.html 来查看storm的运行情况,但是出现了网页一直出现提示loading summary,但是通过透明的弹 ...

  10. MyCP(课下作业)

    一.作业要求 编写MyCP.java 实现类似Linux下cp XXX1 XXX2的功能,要求MyCP支持两个参数: java MyCP -tx XXX1.txt XXX2.bin 用来把文本文件(内 ...