淺談Javascript的靜態屬性和原型屬性_javascript技巧

來源:互聯網
上載者:User

文章給各位介紹Javascript的靜態方法和原型方法一個例子,如果大家對於Javascript的靜態方法和原型方法不瞭解可以和小編一起來看看。 一段代碼,瞭解靜態方法和執行個體方法:

    <script>    //物件建構函數    function Atest(name){      //私人屬性,只能在物件建構函數內部使用      var className = "Atest";      //公有屬性,在對象執行個體化後調用      this.name = name;      //對象方法      this.hello = function(){        alert(this.name);        alert(this.msg());//使用原型方法擴充的方法可以在類內部使用        alert(this.sex);//使用原型方法擴充的屬性可以在類內部使用        alert(Atest.age);//靜態屬性調用時格式為[對象.靜態屬性]      }    }    //類方法 (實際是靜態方法直接調用) 位置:Person類的外部 文法格式:類名稱.方法名稱 = function([參數...]){ 語句行; }    Atest.Run = function(){      alert("我是類方法 Run");    }      //原型方法    Atest.prototype.msg = function(){      alert("我的名字是:"+this.name);//如果原型方法當作靜態方法直接調用時,this.name無法被調用    }     //公有靜態屬性 在類的外部    Atest.age = 20;//公有靜態屬性不能使用 【this.屬性】,只能使用 【對象.屬性】 調用     //原型屬性,當作是類內部的屬性使用【this.原型屬性】,也可以當成公有靜態屬性使用【對象.prototype.原型屬性】    Atest.prototype.sex = "男";     Atest.Run(); //類方法也是靜態方法,可以直接使用 【對象.靜態方法()】    Atest.prototype.msg();//原型方法當成靜態方法使用時【對象.prototype.方法()】     alert(Atest.prototype.sex);//原型屬性當作靜態屬性使用時【對象.prototype.方法()】    var a = new Atest("zhangsan");//對象方法和原型方法需要執行個體化對象後才可以使用    a.hello();//對象方法必須執行個體化對象    a.msg();//原型方法必須執行個體化對象    alert(a.age)://錯誤,公有靜態屬性只能使用 【對象.屬性】調用     //ps:盡量將方法定義為原型方法,原型方法避免了每次調用建構函式時對屬性或方法的構造,節省空間的,建立對象快.  </script>

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.