JavaScript的OO特性:靜態方法

來源:互聯網
上載者:User

所謂靜態方法,是一種屬於類的所有執行個體,不屬於類的特定執行個體的方法,只能由類調用,而不能由類執行個體直接調用.
        在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.’);

 

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.