当你访问一个对象的成员的时候,如果对象自己本身具有,会直接返回给你,停止查询,如果对象自己本身没有,会自动去_proto_上访问,如果有就给你返回结果,停止查询。
一、_proto_和prototype的区别
proto是实例对象用来直接访问构造函数的属性,prototype是函数对象的原型属性。如下:
function App(){
}
App.prototype和new App().proto结果一致,new App().proto指向App.prototype地址:

二、_proto_和prototype的作用
解决了几个构造函数的中包含相同函数时候,创建对象相同函数被创建多次的问题。

app1和app2中fun是一样的,但是被包含在多个对象中,浪费内存。优化后:
function App(name) {
this.name = name
}
App.prototype.fun = function () {
console.log('我执行了')
}
let app1 = new App('张三')
let app2 = new App('李四')
console.log(app1)
console.log(app2)
其他的使用后期再补……,暂时总结这些
JavaScript原型与原型链的理解与应用
本文详细介绍了JavaScript中的_proto_和prototype的区别与作用。_proto_是实例对象访问构造函数属性的途径,而prototype是函数对象的原型属性。通过这两个概念,可以避免在多个构造函数中重复创建相同的函数,节省内存。例如,通过将函数定义在构造函数的prototype上,多个实例可以共享同一份函数,如App.prototype.fun。这种方式优化了内存使用,是JavaScript实现继承的重要机制。
1268

被折叠的 条评论
为什么被折叠?



