JavaScript的OO特性:静态方法
发布时间:2018-08-18 04:39:41 所属栏目:模式 来源:站长网
导读:所谓静态方法,是一种属于类的所有实例,不属于类的特定实例的方法,只能由类调用,而不能由类实例直接调用. 在C#中,声明一个静态方法无疑是非常简单轻松的事,只需要一个关键字:static即可. 那么在 Java Script中,如果我们确定我们需要一个由某个类操纵的方法,
所谓静态方法,是一种属于类的所有实例,不属于类的特定实例的方法,只能由类调用,而不能由类实例直接调用. 在C#中,声明一个静态方法无疑是非常简单轻松的事,只需要一个关键字:static即可. 那么在JavaScript中,如果我们确定我们需要一个由某个类操纵的方法,该怎么做呢? 首先让我们要看一个示例,为类扩充方法.如下: var Employee = function(name,dept){ this.name = name || "none"; this.dept = dept || "general"; } Employee.prototype.toString = function(){ //toString是Employee类的常规方法 return this.name + "&" + this.dept; } 在进行Employee.prototype.toString时,并没有toString函数,由系统进行检测,如果没有,则自动创建toString函数,并把toString对象指向一个匿名函数,这个匿名函数可认为是toString函数的函数体. 注意这里的prototype关键字,它在JavaScript中的地位非常高,是JavaScript实现一些重要机制的必要核心! 现在这个toString方法并不是静态方法,它可以为类实例使用.先说明此方法,是为了下面与静态方法的写法做比较. 如下,为Employee添加一个静态方法show: Employee.show = function (ep){ //show是Employee类的静态方法 alert(ep.toString()); } 可以发现,声明常规方法与静态方法的区别只在于prototype关键字的使用与否. 下面是完整的示例: <script type="text/javascript"> //创建一个类Employee作为基类 var Employee = function(name,dept){ this.name = name || "none"; this.dept = dept || "general"; } Employee.prototype.toString = function(){ //toString是Employee类的常规方法 return this.name + "&" + this.dept; } Employee.show = function (ep){ //show是Employee类的静态方法 alert(ep.toString()); } var ep = new Employee("fanrong","技术部"); Employee.show(ep); //只能由类调用,不能由实例对象调用. //ep.show(ep); //这样回出错 </script> 无论如何,静态方法是OO编程的一个特色,在很多场合都很有用. (编辑:淮安站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |