JavaScript原型prototype

每个函数都有一个prototype属性,这个属性是指向一个对象的引用,这个对象称为原型对象,原型对象包含函数实例共享的方法和属性,也就是说将函数用作构造函数调用(使用new操作符调用)的时候,新创建的对象会从原型对象上继承属性和方法。

当定义一个函数后通过 “.”为其添加的属性和函数,通过对象本身仍然可以访问得到,但是其实例却访问不到,这样的变量和函数分别被称为静态变量和静态函数。例如下面代码:

function Obj(){  }

Obj.a=0; //静态变量
            
 Obj.fn=function(){ //静态函数        
            }
 console.log(Obj.a); //0
 console.log(typeof Obj.fn); //function
            
var o=new Obj();
console.log(o.a); //undefined
console.log(typeof o.fn); //undefined

在面向对象编程中除了一些库函数我们还是希望在对象定义的时候同时定义一些属性和方法,实例化后可以访问,JavaScript也能做到这样,代码如下:

function Obj(){
                this.a=[]; //实例变量
                this.fn=function(){ //实例方法      
      }
 }
  
 console.log(typeof Obj.a); //undefined
 console.log(typeof Obj.fn); //undefined

 var o=new Obj();
console.log(typeof o.a); //object
 console.log(typeof o.fn); //function

无论什么时候,只要创建了一个新函数,就会根据一组特定的规则为该函数创建一个prototype属性,默认情况下prototype属性会默认获得一个constructor(构造函数)属性,这个属性是一个指向prototype属性所在函数的指针  

 

 

posted @ 2015-04-07 15:48  daemom  阅读(389)  评论(0编辑  收藏  举报