• JavaScript的OO特性:静态方法


    所谓静态方法,是一种属于类的所有实例,不属于类的特定实例的方法,只能由类调用,而不能由类实例直接调用.
            在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>
    ****************************************
    * 方法一
    * 类、方法、属性都为静态类型
    * 不能创建实例
    *****************************************/
    var Time = {
        today: ‘2009-3-8′,
        weather: ‘rain’,
        show: function() {
            alert(‘Today is ‘ + this.today);
        }
    };
     
    //静态对象可直接使用,无需创建实例
    alert(‘It is ‘ + Time.weather + ‘ today.’);
    Time.show();
     
    //下面的代码会出错,因为静态类不能创建实例
    //var t = new Time();
    //t.show();
     
    /****************************************
    * 方法二
    * 普通对象,同时拥有静态和非静态属性、方法
    * 可以用实例化
    * 注意:
    *   1.静态方法/属性使用类名访问
    *   2.非静态方法/属性使用实例名访问
    *****************************************/
    function Person(name) {
        //非静态属性
        this.name = name;
        //非静态方法
        this.show = function() {
            alert(‘My name is ‘ + this.name + ‘.’);
        }
    }
    //添加静态属性,人都是一张嘴
    Person.mouth = 1;
    //添加静态方法,哇哇大哭
    Person.cry = function() {
        alert(‘Wa wa wa …’);
    };
    //使用prototype关键字添加非静态属性,每个人的牙可能不一样多
    Person.prototype.teeth = 32;
     
    //非静态方法必须通过类的实例来访问
    var me = new Person(‘Zhangsan’);
    //使用非静态方法、属性
    me.show();
    alert(‘I have ‘ + me.teeth + ‘ teeth.’);
    //使用静态方法、属性
    Person.cry();
    alert(‘I have ‘ + Person.mouth + ‘ mouth.’);

     

    如果这篇文章对您有帮助,您可以打赏我

    技术交流QQ群:15129679

  • 相关阅读:
    电脑右边小键盘默认解锁
    linux关机、重启命令
    linux下Qt设置全屏后再设置指定大小失效
    关闭QEventLoop阻塞失效
    Qt将中文转换成unicode字符串
    vue 中使用vuex和localStorage保存登录状态
    git使用
    jdk11下载与安装
    Navicat安装
    类不平衡问题的评价指标的计算
  • 原文地址:https://www.cnblogs.com/yeminglong/p/3125892.html
Copyright © 2020-2023  润新知