console.log(F.constructor === F) // => true
//表示这个
3.通过构造函数得到的实例对象内部会包含一个指向构造函数的prototype
对象的指针_proto_
var instance = new F()
console.log(instance.proto === F.prototype) // => true
意思是用当前构造函数创建的实例对象内部都包含一个指针,这个指针就是_proto_
,然后这个指针是指向构造函数的prototype对象的
因此我们可以直接用实例访问原型对象上的成员
例:
instance.sayHi() // => 打印hi!
注意
_proto_
是一个非标准属性
prototype属性
Javascript 规定,每一个构造函数都有一个 prototype 属性,指向另一个对象。
这个对象的所有属性和方法,都会被构造函数的实例继承。
这也就意味着,我们可以把所有对象实例需要共享的属性和方法直接定义在prototype对象上。
例子:
function Person (name, age) {
this.name = name
this.age = age
}
console.log(Person.prototype)//打印原型
Person.prototype.type = ‘human’//将human挂载到原型对象的属性上
Person.prototype.sayName = function () {//还可以定义函数
console.log(this.name)
}
let p1 = new Person(…)
let p2 = new Person(…)
console.log(p1.sayName === p2.sayName) // => true
我们可以看到console.log(p1.sayName === p2.sayName)
这行代码打印的结果是true
这是因为所有实例的type
属性和sayName()
方法都是一个同一个内存地址,都是指向prototype
对象,因此提高了运行效率
属性或成员的搜索原则
我们知道了多个实例对象是可以共享原型对象中的属性或成员的,那么js中是怎么实现这个共享机制的呢?
最后
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。
因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!**](https://bbs.csdn.net/topics/618191877)
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!