JavaScript 对象4种不同的类型的属性和方法的访问

1、私有类型:外界完全不具备访问性,要访问它们,只有通过特定的getter和setter。 
2、动态的公有类型:外界可以访问,而且每个对象实例持有一个副本,它们之间不会相互影响。 
3、静态的公有类型,或者通常叫做原型属性:每个对象实例共享唯一副本,对它的改写会相互影响。 
4、类属性:作为类型的属性而不是对象实例的属性,在没有构造对象时也能够访问。

<script language="javascript" type="text/javascript"> 
<!-- 
function dwn(s) 

document.write(s + "<br/>"); 

function myClass() 

var p = 100; //private property; 私有属性 
this.x = 10; //dynamic public property 动态公有属性 

myClass.prototype.y = 20; //static public property or prototype property 原型属性 
myClass.z = 30; //static property //静态属性 
var a = new myClass(); 
dwn(a.p); //undefined 私有属性对象无法访问到 
dwn(a.x); //10 公有属性 
dwn(a.y); //20 公有属性 
a.x = 20; 
a.y = 40; 
dwn(a.x); //20 
dwn(a.y); //40 //动态公有属性y覆盖了原型属性y 
delete(a.x); 
delete(a.y); 
dwn(a.x); //undefined 动态公有属性x被删除后不存在 
dwn(a.y); //20 动态公有属性y被删除后还原为原型属性y 
dwn(a.z); //undefined 类属性无法通过对象访问 
dwn(myClass.z); //30 类属性应该通过类访问 
--> 
</script>

posted @ 2017-07-20 09:30  kathy+  阅读(298)  评论(0编辑  收藏  举报