亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

JavaScript代碼復用模式詳解

2019-11-20 13:57:23
字體:
來源:轉載
供稿:網友

代碼復用及其原則

代碼復用,顧名思義就是對曾經編寫過的代碼的一部分甚至全部重新加以利用,從而構建新的程序。在談及代碼復用的時候,我們首先可以想到的是繼承性。代碼復用的原則是:

優先使用對象組合,而不是類繼承

在js中,由于沒有類的概念,因此實例的概念也就沒多大意義,js中的對象是簡單的鍵-值對,可以動態的創建和修改它們。

但在js中,我們可以使用構造函數和new操作符來實例化一個對象,這與其他使用類的編程語言在語法上有其相似之處。

例如:

var trigkit4 = new Person();

js在調用構造函數Person時似乎看起來是一個類,但其實際上仍然是一個函數,這讓我們產生了一些假定在類的基礎上的開發思路和繼承模式,我們可以稱之為“類式繼承模式”。

傳統的繼承模式是需要class關鍵字的,我們假定以上的類式繼承模式為現代繼承模式,這是一種不需要以類的方式考慮的模式。

類式繼承模式

看下面兩個構造函數Parent()Child()的例子:

<script type="text/javascript">
    function Parent(name){
        this.name = name || 'Allen';
    }
    Parent.prototype.say = function(){
        return this.name;
    }
    function Child(name){}
    //用Parent構造函數創建一個對象,并將該對象賦值給Child原型以實現繼承
    function inherit(C,P){
        C.prototype = new P();//原型屬性應該指向一個對象,而不是函數
    }
    //調用聲明的繼承函數
    inherit(Child,Parent);
</script>

當使用new Child()語句創建一個對象時,它會通過原型從Parent()實例獲取它的功能,比如:

var kid = new Child();kid.say();//Allen

原型鏈

討論一下類式繼承模式下原型鏈的工作原理,我們將對象看做是內存中某處的塊,該內存塊包含數據以及指向其他塊的引用。當用new Parent()語句創建一個對象時,就會創建如下圖左邊的這樣一個塊,這個塊保存了name屬性,如果想訪問say()方法,我們可以通過指向構造函數Parent()prototype(原型)屬性的隱式鏈接__proto__,便可訪問右邊區塊Parent.prototype。

那么,當使用var kid = new Child()創建新對象時會發生什么?如下圖:

使用new Child()語句所創建的對象除了隱式鏈接__proto__外,它幾乎是空的。這種情況下,__proto__指向了在inherit()函數中使用new Parent()語句所創建的對象

當執行kid.say()時,由于最左下角的區塊對象并沒有say()方法,因此他將通過原型鏈查詢中間的區塊對象,然而,中間的區塊對象也沒有say()方法,因此他又順著原型鏈查詢到最右邊的區塊對象,而該對象正好有say()方法。完了嗎?

執行到這里的時候并沒有完,在say()方法中引用了this.name,this指向構造函數所創建的對象,在這里,它指向了new Child()這個區塊,然而,new Child()中并沒有name屬性,為此,將查詢中間區塊,而中間區塊正好有name屬性,至此,原型鏈的查詢完畢。

更詳細的討論請查看我這篇文章:javascript學習筆記(五)原型和原型鏈詳解

共享原型

本模式的法則在于:可復用的成員應該轉移到原型中而不是放置在this中。因此,處于繼承的目的,任何值得繼承的東西都應該放在原型中實現。所以,可以將子對象的原型與父對象的原型設置為相同即可,如下示例所示:

function inherit(C,P){
    C.prototype = P.prototype;
}

子對象和父對象共享同一個原型,并且可以同等的訪問say()方法。然而,子對象并沒有繼承name屬性

原型繼承

原型繼承是一種“現代”無類繼承模式??慈缦聦嵗?/p>

<script type="text/javascript">
    //要繼承的對象
    var parent = {
        name : "Jack"  //這里不能有分號哦
    };
    //新對象
    var child = Object(parent);
    alert(child.name);//Jack
</script>

在原型模式中,并不需要使用對象字面量來創建父對象。如下代碼所示,可以使用構造函數來創建父對象,這樣做的話,自身的屬性和構造函數的原型的屬性都將被繼承。

<script type="text/javascript">
    //父構造函數
    function Person(){
        this.name = "trigkit4";
    }
    //添加到原型的屬性
    Person.prototype.getName = function(){
        return this.name;
    };
    //創建一個新的Person類對象
    var obj = new Person();
    //繼承
    var kid = Object(obj);
    alert(kid.getName());//trigkit4
</script>

本模式中,可以選擇僅繼承現有構造函數的原型對象。對象繼承自對象,而不論父對象是如何創建的,如下實例:

<script type="text/javascript">
    //父構造函數
    function Person(){
        this.name = "trigkit4";
    }
    //添加到原型的屬性
    Person.prototype.getName = function(){
        return this.name;
    };
    //創建一個新的Person類對象
    var obj = new Person();
    //繼承
    var kid = Object(Person.prototype);
    console.log(typeof kid.getName);//function,因為它在原型中
    console.log(typeof kid.name);//undefined,因為只有該原型是繼承的
</script>

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
中文字幕亚洲专区| 午夜免费在线观看精品视频| 欧美精品久久一区二区| 国产精品91在线观看| 日韩中文字幕欧美| 日韩在线观看网站| 91av视频在线免费观看| 久久精品成人动漫| 亚洲天堂网在线观看| 国产午夜精品久久久| 欧美日韩综合视频网址| 精品色蜜蜜精品视频在线观看| 国产精品欧美亚洲777777| 欧美日韩午夜剧场| 国产成人+综合亚洲+天堂| 亚洲风情亚aⅴ在线发布| 91精品国产高清| 国产不卡一区二区在线播放| 国产丝袜精品第一页| 亚洲a∨日韩av高清在线观看| 亚洲最新中文字幕| 国产精品激情av在线播放| 久久久久久久久久久久av| 日日骚久久av| 成人日韩在线电影| 欧美性猛交xxxx免费看漫画| 亚洲福利在线播放| 懂色aⅴ精品一区二区三区蜜月| 欧美日韩美女在线观看| 欧美在线免费看| 国产suv精品一区二区三区88区| 久久国产精品久久久| 中文字幕久热精品视频在线| 精品国产户外野外| 久久久久久九九九| 精品福利樱桃av导航| 96sao精品视频在线观看| 91国内揄拍国内精品对白| 成人免费高清完整版在线观看| 国产在线不卡精品| 日韩欧美亚洲成人| 精品国产网站地址| 久久国产精品久久久| 高清欧美一区二区三区| 国产日产欧美a一级在线| 国产精品视频久久| 欧美日韩第一视频| 成人激情黄色网| 国产精品美女无圣光视频| 欧美人与性动交| 国内精品免费午夜毛片| 国产精品白嫩初高中害羞小美女| 日本高清不卡的在线| 久久九九全国免费精品观看| 奇米4444一区二区三区| 成人免费看片视频| 91久久久亚洲精品| 在线免费观看羞羞视频一区二区| 久久人人看视频| 日本老师69xxx| 国产欧美精品xxxx另类| 日韩经典一区二区三区| 亚洲欧美国内爽妇网| 色噜噜狠狠狠综合曰曰曰| 国产精品视频午夜| 亚洲国产精品va在线观看黑人| 8090成年在线看片午夜| 91视频88av| www.日韩.com| www.日韩欧美| 久久精品国产69国产精品亚洲| 亚洲自拍另类欧美丝袜| 国产精品香蕉在线观看| 一区二区欧美久久| 日韩欧美视频一区二区三区| 亚洲视频999| 欧美韩国理论所午夜片917电影| 日韩精品视频在线观看免费| 国产精品69久久久久| 国产精品久久久久久久久久尿| 久久精品电影网| 欧美疯狂做受xxxx高潮| 91沈先生作品| 欧美噜噜久久久xxx| 久久久噜噜噜久久中文字免| 亚洲国产一区二区三区四区| 一区二区在线免费视频| 亚洲国产精品大全| 91成人在线视频| 精品视频9999| 国产激情视频一区| 欧美xxxx做受欧美| 欧美有码在线观看| 欧美韩国理论所午夜片917电影| 欧美在线一区二区三区四| 亚洲一二在线观看| 日韩中文字幕在线视频播放| 国产91精品久久久久久久| 久久久久久久亚洲精品| 最近中文字幕日韩精品| 久久在线观看视频| 国产精品第七影院| 国产精品久久久久久中文字| 国产美女精品视频免费观看| 国产欧美日韩免费| 日韩在线观看免费全| 欧美专区在线观看| 国产91av在线| 久久精品国产亚洲| 米奇精品一区二区三区在线观看| 国产精品jvid在线观看蜜臀| 国产丝袜高跟一区| 91精品国产乱码久久久久久蜜臀| 亚洲色图美腿丝袜| 日韩欧美中文第一页| 91在线精品播放| 国产极品精品在线观看| 国产精品极品美女粉嫩高清在线| 精品久久久久久久久久久久久| 亚洲福利在线看| 成人日韩在线电影| 亚洲国产古装精品网站| 亚洲理论电影网| 91精品久久久久久久久中文字幕| 91精品视频免费| 中文字幕欧美精品日韩中文字幕| 日本午夜人人精品| 国产精品香蕉国产| 亚洲电影免费观看| 久久久成人av| 久久高清视频免费| 国产精品日韩在线播放| 色偷偷噜噜噜亚洲男人| 91免费版网站入口| 亚洲国产精品视频在线观看| 中文字幕亚洲一区| 91免费看片网站| 国产成人精品在线| 欧美午夜精品在线| 日韩中文字幕视频| 日韩av资源在线播放| 久久久久一本一区二区青青蜜月| 久久久久久久久久久国产| 精品中文字幕在线2019| 久久久国产精品视频| 成人国产在线激情| 久久这里只有精品99| 91精品视频免费观看| 欧美成人黄色小视频| 欧美日韩第一页| 成人久久一区二区| 4438全国亚洲精品在线观看视频| 国产精品欧美一区二区三区奶水| 日韩中文字幕在线看| 国产精品视频公开费视频| 亚洲精品日产aⅴ| 亚洲美女福利视频网站| 国产一区二区三区在线播放免费观看| 精品国产欧美一区二区五十路| 亚洲一区国产精品| 国产69精品久久久久9| 亚洲精品91美女久久久久久久| 中文字幕日韩欧美在线| 久久久国产精品视频|