<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    Flyingis

    Talking and thinking freely !
    Flying in the world of GIS !
    隨筆 - 156, 文章 - 16, 評論 - 589, 引用 - 0
    數(shù)據(jù)加載中……

    JavaScript 中的繼承(上)

    ??? 作者:Flyingis

    ??? 繼承是面向對象語言基本特征之一,通過繼承可以將父類所具有的特性遺傳到子類。ECMAScript中的繼承不像Java、C++等語言那么明顯,直接通過關鍵字來實現(xiàn),通常它是通過模擬方式來實現(xiàn)繼承功能的,并且實現(xiàn)方式有多種。

    ??? 在繼承中引入this關鍵字,使用構造器方法定義類來實現(xiàn)繼承。一個構造器是一個函數(shù),因此可以將父類的構造器作為子類的一個方法使用并進行調用。

    function ClassA(id) {
    ??
    this .id = id;
    ??
    this .sayId =?function() {
    ???? alert(
    this.id);
    ?? }
    ;
    }


    function ClassB(id,?name) {
    ??
    this .newMethod = ClassA;
    ??
    this .newMethod(id);
    ??
    delete?this.newMethod;

    ??
    this.name= name;
    ??
    this.sayName=?function(){
    ???? alert(
    this.name);
    ?? }
    ;
    }

    ??? 注意,子類中所有新的屬性和方法都必需在刪除newMethod后引入,否則,可能存在用父類的屬性和方法重寫子類屬性和方法的危險。另外,使用這種方法還可以實現(xiàn)多重繼承,此時如果兩個父類具有相同的屬性或方法時,最后的類具有優(yōu)先級。由于這種繼承方法比較流行,ECMAScript第三版引入了兩個Function對象:call()和apply()。

    ??? call()

    ??? call()方法是最接近上述繼承方式的方法,它的第一個參數(shù)是this指向的對象,所有的其他參數(shù)都直接傳到function。

    function sayMessage(first,?last)?{
    ?? alert(first
    +?this.logic +last);
    }
    ;

    varobj =new Object();
    obj.logic
    =?"or";

    sayMessage.call(obj,
    "Coffee ",?"Tea");??//輸出"Coffee?or?Tea"

    ??? 用call()方法來實現(xiàn)繼承,只需要this.newMethod相關的三行代碼。

    function ClassB(id,?name) {
    ??
    ? //this.newMethod?=?ClassA;
    ??//this.newMethod(id);
    ??//delete?this.newMethod;
    ??ClassA.call(this,?id);??//this指向ClassB的對象

    ??
    this.name =name;
    ??
    this.sayName =?function()?{
    ???? alert(
    this.name);
    ?? }
    ;
    }

    ??? apply()

    ??? apply()方法需要兩個參數(shù):this所指向的對象,和傳到function的由參數(shù)組成的array。

    function?sayMessage(first,?last)??{
    ??alert(first?
    +?this.logic?+last);
    }
    ;

    var?obj?=?new?Object();
    obj.logic?
    =?"or";

    sayMessage.apply(obj,?
    new?Array("Coffee?",?"?Tea"));??//輸出"Coffee?or?Tea"
    ??
    ??? 同樣,使用 apply() 實現(xiàn)繼承可以通過如下方法實現(xiàn)。

    function?ClassB(id,?name)?{
    ??
    //this.newMethod?=?ClassA;
    ??//this.newMethod(id);
    ??//delete?this.newMethod;
    ??ClassA.apply(this,?new?Array(id));??//this指向ClassB的對象

    ??
    this.name?=?name;
    ??
    this.sayName?=?function()?{
    ????alert(
    this.name);
    ??}
    ;
    }

    ??? 當父類構造器的參數(shù)和子類構造器參數(shù)的順序一致時,可以使用子類的arguments對象作為第二個參數(shù)。否則,必需創(chuàng)建一個array來傳遞參數(shù),或是使用call()方法。

    ??? 文章待續(xù)……

    posted on 2006-07-15 10:38 Flyingis 閱讀(1618) 評論(0)  編輯  收藏 所屬分類: Web 客戶端技術

    主站蜘蛛池模板: 精品久久8x国产免费观看| 午夜影视日本亚洲欧洲精品一区| 亚洲av成人中文无码专区| 四虎影视永久免费观看网址| 国产三级在线免费观看| 亚洲av伊人久久综合密臀性色| 在线人成精品免费视频| 亚洲欧美日本韩国| 久久久亚洲精品蜜桃臀| 猫咪免费人成网站在线观看| 亚洲日韩AV一区二区三区四区| 亚洲精品99久久久久中文字幕 | 国产99在线|亚洲| 伊在人亚洲香蕉精品区麻豆| 男人的天堂网免费网站| 中文日韩亚洲欧美制服| 国产亚洲人成A在线V网站| 在线视频精品免费| 四虎永久在线精品免费一区二区| 亚洲丁香色婷婷综合欲色啪| 精品剧情v国产在免费线观看| 两个人看的www免费| 亚洲小说图区综合在线| 亚洲gv白嫩小受在线观看| 天天摸天天操免费播放小视频| 中国一级毛片视频免费看| 亚洲香蕉在线观看| 亚洲日韩中文字幕在线播放| 嫩草视频在线免费观看| 精品四虎免费观看国产高清午夜 | 亚洲砖码砖专无区2023| 亚洲国产婷婷六月丁香| 天天摸天天操免费播放小视频| 中文字幕无码免费久久| 亚洲va中文字幕| 亚洲精品福利在线观看| 亚洲综合精品网站| 日本免费观看网站| 91免费人成网站在线观看18| a级毛片免费在线观看| 香蕉视频亚洲一级|