Ext學習筆記二(類定義)

來源:互聯網
上載者:User

 在Ext中使用如下語句便可以定義一個類,

 

  1. Person = Ext.emptyFn;

當然這樣定義的類只是一個空架子,沒有任何屬性和方法,使用下面的代碼為其添加屬性和方法

 

  1. Ext.apply(Person.prototype, {
  2.               name: "Chris Mao",  //自訂屬性
  3.               print: function() { //自訂方法
  4.                       alert(this.name); 
  5.                     }
  6.         });

使用命名空間
熟悉物件導向編程的朋友都瞭解命名空間這個概念,Ext同樣支援命名空間。

 

  1. Ext.namespace("Ext.Emerson"); //定義命名空間
  2. Ext.Emerson.Person = Ext.emptyFn;
  3. Ext.apply(Ext.Emerson.Person.prototype, {
  4.               name: "Chris Mao",  //自訂屬性
  5.               print: function() { //自訂方法
  6.                       alert(this.name); 
  7.                     }
  8.         });

使用樣本:

  1. <html>
  2.   <head>
  3.     <link rel="stylesheet" type="text/css" href="http://plt385130:8080/ext-2.2/resources/css/ext-all.css"/>
  4.     <script type="text/javascript" src="http://plt385130:8080/ext-2.2/adapter/ext/ext-base.js"></script>
  5.     <script type="text/javascript" src="http://plt385130:8080/ext-2.2/ext-all.js"></script>
  6.     <script type="text/javascript" src="Person.js"></script>
  7.     <script type="text/javascript">
  8.       var p = new Ext.Emerson.Person();
  9.       p.name = 'Chris Mao'; //屬性賦值
  10.       p.print();            //調用print()方法
  11.     </script>
  12.   </head>
  13.   <body>
  14.   </body>
  15. </html>

定義建構函式

  1. Ext.namespace("Ext.Emerson"); //定義命名空間
  2. Ext.Emerson.Person = function(_cfg) {
  3.   //do something
  4.   Ext.apply(this, _cfg);
  5. };
  6. Ext.apply(Ext.Emerson.Person.prototype, {
  7.               print: function() { //自訂方法
  8.                       alert(this.name); 
  9.                     }
  10.         });

使用樣本

  1. <html>
  2.   <head>
  3.     <link rel="stylesheet" type="text/css" href="http://plt385130:8080/ext-2.2/resources/css/ext-all.css"/>
  4.     <script type="text/javascript" src="http://plt385130:8080/ext-2.2/adapter/ext/ext-base.js"></script>
  5.     <script type="text/javascript" src="http://plt385130:8080/ext-2.2/ext-all.js"></script>
  6.     <script type="text/javascript" src="Person.js"></script>
  7.     <script type="text/javascript">
  8.       var p = new Ext.Emerson.Person({name: "Chris Mao"});
  9.       p.print();            //調用print()方法
  10.     </script>
  11.   </head>
  12.   <body>
  13.   </body>
  14. </html>

       
定義類靜態方法

  1. Ext.Emerson.Person.print = function(_name) {
  2.  var p = new Ext.Emerson.Person();
  3.  p.name = _name;
  4.  p.print();
  5. }

使用樣本

  1. <html>
  2.   <head>
  3.     <link rel="stylesheet" type="text/css" href="http://plt385130:8080/ext-2.2/resources/css/ext-all.css"/>
  4.     <script type="text/javascript" src="http://plt385130:8080/ext-2.2/adapter/ext/ext-base.js"></script>
  5.     <script type="text/javascript" src="http://plt385130:8080/ext-2.2/ext-all.js"></script>
  6.     <script type="text/javascript" src="Person.js"></script>
  7.     <script type="text/javascript">
  8.       var p = new Ext.Emerson.Person();
  9.       
  10.       //調用靜態方法
  11.       Ext.Emerson.Person.print('毛子兵');
  12.     </script>
  13.   </head>
  14.   <body>
  15.   </body>
  16. </html>

類繼承

定義一個Student類,繼承於Person類,並添加了Job屬性。

  1. Ext.Emerson.Student = function(_cfg) {
  2.   //do something
  3.   Ext.apply(this, _cfg);
  4. };
  5. Ext.extend(Ext.Emerson.Student, Ext.Emerson.Person, {job: "學生"});

 

聯繫我們

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