JavaScript的对象访问机制
Posted 一杯清泉
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JavaScript的对象访问机制相关的知识,希望对你有一定的参考价值。
当你访问一个对象的成员的时候,如果对象自己本身具有,会直接返回给你,停止查询,如果对象自己本身没有,会自动去_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的对象访问机制的主要内容,如果未能解决你的问题,请参考以下文章