JavaScript的OO特性:静态方法

       所谓静态方法,是一种属于类的所有实例,不属于类的特定实例的方法,只能由类调用,而不能由类实例直接调用.
        在C#中,声明一个静态方法无疑是非常简单轻松的事,只需要一个关键字:static即可.
        那么在JavaScript中,如果我们确定我们需要一个由某个类操纵的方法,该怎么做呢?
        首先让我们要看一个示例,为类扩充方法.如下:

ExpandedBlockStart.gif      var  Employee  =   function (name,dept) {
InBlock.gif        
this.name = name || "none";
InBlock.gif        
this.dept = dept || "general";
ExpandedBlockEnd.gif    }

ExpandedBlockStart.gif    Employee.prototype.toString 
=   function () {  //toString是Employee类的常规方法
InBlock.gif
        return this.name + "&" + this.dept;
ExpandedBlockEnd.gif    }
        在进行Employee.prototype.toString时,并没有toString函数,由系统进行检测,如果没有,则自动创建toString函数,并把toString对象指向一个匿名函数,这个匿名函数可认为是toString函数的函数体.
        注意这里的prototype关键字,它在JavaScript中的地位非常高,是JavaScript实现一些重要机制的必要核心!
        现在这个toString方法并不是静态方法,它可以为类实例使用.先说明此方法,是为了下面与静态方法的写法做比较.
        如下,为Employee添加一个静态方法show:
ExpandedBlockStart.gif     Employee.show  =   function  (ep) {      //show是Employee类的静态方法
InBlock.gif
        alert(ep.toString());
ExpandedBlockEnd.gif    }
        可以发现,声明常规方法与静态方法的区别只在于prototype关键字的使用与否.
        下面是完整的示例:
None.gif < script type = " text/javascript " >
None.gif    
// 创建一个类Employee作为基类
ExpandedBlockStart.gif
     var  Employee  =   function (name,dept) {
InBlock.gif        
this.name = name || "none";
InBlock.gif        
this.dept = dept || "general";
ExpandedBlockEnd.gif    }

ExpandedBlockStart.gif    Employee.prototype.toString 
=   function () {  //toString是Employee类的常规方法
InBlock.gif
        return this.name + "&" + this.dept;
ExpandedBlockEnd.gif    }

None.gif
ExpandedBlockStart.gif    Employee.show 
=   function  (ep) {      //show是Employee类的静态方法
InBlock.gif
        alert(ep.toString());
ExpandedBlockEnd.gif    }

None.gif    
var  ep  =   new  Employee( " fanrong " , " 技术部 " );
None.gif    Employee.show(ep);          
// 只能由类调用,不能由实例对象调用.
None.gif
     // ep.show(ep);            //这样回出错
None.gif
</ script >
        无论如何,静态方法是OO编程的一个特色,在很多场合都很有用.

转载于:https://www.cnblogs.com/200831856/archive/2009/09/15/javascript_static_two.html

猜你喜欢

转载自blog.csdn.net/weixin_33786077/article/details/93711333
oo