春天的木頭要發(fā)芽

          很累。但不能懶

          BlogJava 首頁 新隨筆 聯(lián)系 聚合 管理
            1 Posts :: 0 Stories :: 0 Comments :: 0 Trackbacks

          常用鏈接

          留言簿

          隨筆分類

          隨筆檔案

          文章分類

          搜索

          最新評論

          在prototype框架中的類繼承實現(xiàn)機制
          //為Object類添加靜態(tài)方法:extend
          Object.extend = function(destination, source) {
            for(property in source) {
               destination[property] = source[property];
            }
            return destination;
          }
          //通過Object類為每個對象添加方法extend
          Object.prototype.extend = function(object) {
            return Object.extend.apply(this, [this, object]);
          }
          Object.extend方法很容易理解,它是Object類的一個靜態(tài)方法,用于將參數(shù)中source的所有屬性都賦值到destination對象中,并返回destination的引用。下面解釋一下Object.prototype.extend的實現(xiàn),因為Object是所有對象的基類,所以這里是為所有的對象都添加一個extend方法,函數(shù)體中的語句如下:
          Object.extend.apply(this,[this,object]);
          這一句是將Object類的靜態(tài)方法作為對象的方法運行,第一個參數(shù)this是指向?qū)ο髮嵗陨恚坏诙€參數(shù)是一個數(shù)組,包括兩個元素:對象本身和傳進來的對象參數(shù)object。函數(shù)功能是將參數(shù)對象object的所有屬性和方法賦值給調(diào)用該方法的對象自身,并返回自身的引用。有了這個方法,下面看類繼承的實現(xiàn):
          <script language="JavaScript" type="text/javascript">
          <!--
          //定義extend方法
          Object.extend = function(destination, source) {
            for (property in source) {
               destination[property] = source[property];
            }
            return destination;
          }
          Object.prototype.extend = function(object) {
            return Object.extend.apply(this, [this, object]);
          }
          //定義class1
          function class1(){
                //構(gòu)造函數(shù)
          }
          //定義類class1的成員
          class1.prototype={
                method:function(){
                     alert("class1");
                },
                method2:function(){
                     alert("method2");
                }

          }
          //定義class2
          function class2(){
                //構(gòu)造函數(shù)
          }
          //讓class2繼承于class1并定義新成員
          class2.prototype=(new class1()).extend({
                method:function(){
                     alert("class2");
                }
          });

          //創(chuàng)建兩個實例
          var obj1=new class1();
          var obj2=new class2();
          //試驗obj1和obj2的方法
          obj1.method();
          obj2.method();
          obj1.method2();
          obj2.method2();
          //-->
          </script>
          從運行結(jié)果可以看出,繼承被正確的實現(xiàn)了,而且派生類的額外成員也可以以列表的形式加以定義

          posted on 2009-11-25 14:23 春木 閱讀(98) 評論(0)  編輯  收藏 所屬分類: JavaScript

          只有注冊用戶登錄后才能發(fā)表評論。


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 墨竹工卡县| 云梦县| 南开区| 苍南县| 颍上县| 广安市| 凤台县| 广汉市| 南投市| 东平县| 遵义市| 龙泉市| 眉山市| 南郑县| 龙门县| 汶川县| 东阿县| 兴化市| 神池县| 衢州市| 南和县| 扎赉特旗| 平山县| 无极县| 连平县| 九江市| 卓资县| 陕西省| 滁州市| 叶城县| 界首市| 绿春县| 伊金霍洛旗| 昌江| 漳平市| 盐边县| 桂林市| 江达县| 北宁市| 砀山县| 云霄县|