浅谈JavaScript原型图与内存模型

js原型详解

1.内存模型:

 

1.原型是js中非常特殊一个对象,当一个函数(Person)创建之后,会随之就产生一个原型对象

2. 当通过这个函数的构造函数创建了一个具体的对象(p1)之后,在这个具体的对象中就会有一个属性指向原型

2.演示

 

以下演示了通过原型的创建方式,使用基于原型的创建可以将属性和方法
  设置为Person专有的,不能再通过window来调用,如此就完成了封装

 <script type="text/javascript">
function
Person(){ } Person.prototype.name = "gui"; Person.prototype.age = 20; Person.prototype.say = function(){ alert(this.name+","+this.age); } var p1 = new Person(); p1.say();//gui,20 p1.name="gui22"; p1.say();//gui22,20
     //通过window没有办法调用say方法
        say();

var p2 = new Person(); p2.say();//gui,20
</script>

 

【注】p1有自己的内存空间p1.name="gui22";只是改变了自己内存空间的name,并未触及原型中的name

 

 

3.下面是一些判断函数有助于理解原型图

 

//检测某个对象是否指向该函数的原型

       // alert(Person.prototype.isPrototypeOf(p1));//true

          

        //检测某个对象的constructor

      //  alert(p1.constructor == Person);//true

 

//检测某个对象是否是自己的属性
        //alert(p1.hasOwnProperty("name"));//true,p1在自己的空间中设置了name属性
        //alert(p2.hasOwnProperty("name"));//false

 

//删除某个对象的某个属性
      //  delete p1.name;
       //  alert(p1.hasOwnProperty("name"));//false,由于已经删除了

 

     

   //检测某个对象在原型或者自己中是否包含有某个属性,通过in检测

   //alert("name" in p1);

   //alert("name" in p2);

    //alert("gender" in p1);//gender(性别),在原型和自己的空间中都没有,false

posted @ 2019-10-24 16:38  月半Halfmoonly  阅读(184)  评论(0编辑  收藏  举报