JavaScript中对象成员的可见性

与java等基于类的面向对象语言的private、protected、public等关键字的用途类似,基于对象的JavaScript语言,在对象构造上也存在类似的成员可见性问题。

  JavaScript对象构造的可见性定义可以分为以下几种:

  1,私有属性(private properties)
  
  通过var关键字定义对象构造中变量的作用域,该变量只能在对象构造方法的作用域内被访问。如:

function  VariableTest()
{
      
var  myVariable; // private
}

var  vt  =   new  VariableTest();
vt.myVariable;
// 这里会出现undefined异常

  2,私有方法(private methods)

  与私有属性类似,只能在对象构造方法作用域内被访问。如:

ContractedBlock.gif ExpandedBlockStart.gif Code
function MethodTest()
{
      
var myMethod = function()//private
      {
            alert(
"private method");
      }
      
      
this.invoke = function()
      {
            
//能够访问到myMethod
            myMehtod();
      }
}

var mt = new MethodTest();
mt.myMethod();
//错误。使用trycatch的话,可捕获“对象不支持此属性或方法”异常
mt.invoke();

  3,公共属性(public properties)

  有两种定义公共属性的途径:

  (1)通过this关键字来定义。如:

function  PrivilegedVariable()
{
      
this .variable  =   " privileged variable " ;
}

var  pv  =   new  PrivilegedVariable();
pv.variable;
// 返回 "privileged variable"

  (2)通过构造方法的原型来定义。如:

function  PublicVariable(){}
PublicVariable.prototype.variable 
=   " public variable " ;
var  pv  =   new  PublicVariable();
pv.variable;
// 返回"public variable"

  4,公共方法(public methods)

  同理,有两种定义公共方法的途径。
  
  (1)通过this关键字来定义。(2)通过构造方法的原型来定义。

  这里省略。。。。。。。。。。。

  5,静态属性(static properties)

  直接为对象构造方法添加的属性,不能被对象实例访问,只能供构造方法自身使用。如:

ContractedBlock.gif ExpandedBlockStart.gif Code
function StaticVariable(){}
StaticVariable.variable 
= "static variable";

var sv = new StaticVariable();
sv.variable;
//返回"undefined"
StaticVariable.prototype.variable;//返回"undefined"
StaticVariable.variable;//返回"static variable"

  6,静态方法(static methods)

  直接为对象构造方法添加的方法,不能被对象实例访问,只能供构造方法自身使用。

  代码省略。。。。。。。。

转载于:https://www.cnblogs.com/gisland/archive/2009/10/16/1584688.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值