注册 登录  
 加关注
查看详情
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

前端开发那点事儿

冒犯之处,敬请谅解。

 
 
 

日志

 
 
 
 

js对象的四种类型的属性、方法的访问  

2012-04-25 17:38:21|  分类: JS |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |


1、私有类型:外界完全不具备访问性,要访问它们,只有通过特定的gettersetter
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>

 

 

备注:动态共有属性优于原型属性。即:如果二者都定义了同一属性,则最终的属性值以动态公有属性为准。

  评论这张
 
阅读(680)| 评论(0)
推荐 转载

历史上的今天

在LOFTER的更多文章

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2018