原始的原型链是怎样玩的

带着问题看代码:

1、原始的继承是怎样实现继承的? A类的prototype 属性 = B类的实例

2、实现继承后,连B类的中实例的属性(放在了A类的prototype中)和原型链的上的东西都可以用

3、A.prototype.constructor实际上已经指向了B--被重写了(但是不影响对实际代码运行的理解)

4、原型链继承,是往上找,找到了直接就用了,就不再往上找了

javascript 复制代码
function subType (j) {
  this.name = 'subType'
  this.nameJ = j
}
subType.prototype.getValue = function () {
  return  'subType原型上的值'
}

function deviceType (k) {
  this.nameOther = 'deviceTye'
  this.nameK = k
}
// 这种方法实现的继承,就是连constructor中的属性就也给继承了
deviceType.prototype = new subType()
deviceType.prototype.getValueOther= function() {
  return 'deviceType原型链上的值'
}

let instance = new deviceType(99)

// 继承的表现,可以看到自己原型上的,和继承某个实例对象原型链上的东西
console.log(instance.nameOther) // deviceTye
console.log(instance.name) // subType
console.log(instance.getValueOther()) // deviceType原型链上的值
console.log(instance.getValue())  // subType原型上的值

// 这行打印可以看到是怎样的,(继承某个实例的属性)会放在deviceType.prototype.
console.log(instance.__proto__) // { name: 'subType', getValueOther: [Function (anonymous)] }

// 会发现被重写了
console.log(instance.constructor) //  [Function: subType]
// 打印一下完整的原型链
console.log(instance.__proto__.__proto__.constructor) // [Function: subType]

// 虽然被重写了,但是不影响实例化
console.log(instance.nameK)  // 99
console.log(instance.nameJ) // undefined
相关推荐
Buleall几秒前
期末考学C
java·开发语言
重生之绝世牛码2 分钟前
Java设计模式 —— 【结构型模式】外观模式详解
java·大数据·开发语言·设计模式·设计原则·外观模式
小蜗牛慢慢爬行8 分钟前
有关异步场景的 10 大 Spring Boot 面试问题
java·开发语言·网络·spring boot·后端·spring·面试
Algorithm157618 分钟前
云原生相关的 Go 语言工程师技术路线(含博客网址导航)
开发语言·云原生·golang
shinelord明28 分钟前
【再谈设计模式】享元模式~对象共享的优化妙手
开发语言·数据结构·算法·设计模式·软件工程
Monly2134 分钟前
Java(若依):修改Tomcat的版本
java·开发语言·tomcat
boligongzhu35 分钟前
DALSA工业相机SDK二次开发(图像采集及保存)C#版
开发语言·c#·dalsa
Eric.Lee202135 分钟前
moviepy将图片序列制作成视频并加载字幕 - python 实现
开发语言·python·音视频·moviepy·字幕视频合成·图像制作为视频
7yewh38 分钟前
嵌入式Linux QT+OpenCV基于人脸识别的考勤系统 项目
linux·开发语言·arm开发·驱动开发·qt·opencv·嵌入式linux
长风清留扬40 分钟前
小程序毕业设计-音乐播放器+源码(可播放)下载即用
javascript·小程序·毕业设计·课程设计·毕设·音乐播放器