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的对象访问机制的主要内容,如果未能解决你的问题,请参考以下文章

深入理解 Javascript 面向对象编程(转)

JavaScript 之 创建对象

JavaScript构造函数,原型对象原型链,this指向,错误处理

JavaScript的几种常见的创建方式

javaScript 数组对象取出某一列

JavaScript的垃圾回收机制