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

首頁 > 編程 > JavaScript > 正文

javascript繼承機制實例詳解

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

本文實例講述了javascript繼承機制。分享給大家供大家參考。具體分析如下:

初學javascript一般很難理解Javascript語言的繼承機制它沒有"子類"和"父類"的概念,也沒有"類"(class)和"實例"(instance)的區分,全靠一種很奇特的"原型鏈"(prototype chain)模式,來實現繼承。

我花了很多時間,學習這個部分,還做了很多筆記。但是都屬于強行記憶,無法從根本上理解。

一、如何創建一個類

假設有給叫Person的類如下:

復制代碼 代碼如下:
var Person = function(name, age) {
    this.name = name;
    this.age = age;
}
Person.prototype.getName = function() {
    return this.name;
}

如上:Person代表地球上所有的人,每個人都有這兩個基本屬性:name和age;現在我們要實現一個學生類,然后我們知道了; 學生也是一個人,及學生也有name和age等屬性;現在的問題是怎么能把這個關系給搭起來?
先來看看純面向對象的語言是如何做到的(如:Actionscrpt3)
復制代碼 代碼如下:
class Students extend Person {}; //很簡單,一行代碼;更確切的說是一個單詞--extend

二、換成js如何能做到

在講解js的繼承機制實現之前,先了解一下js的原型鏈:

復制代碼 代碼如下:
var person = new Person('Poised-flw', 21);
person.getName(); // "Poised-flw"

就上面的getName()方法來說,是如何執行的?首先會在Person這個函數里面找是否有getName()這個方法,發現沒有;然后就轉到 Person.prototype中尋找,發現有!然后就調用,若沒有呢?繼續按照相同的方法一直沿著prototype尋找下去,直到找到方法或者 達到原型鏈的頂端為止!

舉例來說,現在有一個叫做DOG的構造函數,表示狗對象的原型。

復制代碼 代碼如下:
  function DOG(name){
    this.name = name;
  }

對這個構造函數使用new,就會生成一個狗對象的實例。
復制代碼 代碼如下:
  var dogA = new DOG('大毛');
  alert(dogA.name); // 大毛

注意構造函數中的this關鍵字,它就代表了新創建的實例對象。

三、new運算符的缺點

用構造函數生成實例對象,有一個缺點,那就是無法共享屬性和方法。
比如,在DOG對象的構造函數中,設置一個實例對象的共有屬性species。

復制代碼 代碼如下:
  function DOG(name){
    this.name = name;
    this.species = '犬科';
  }

然后,生成兩個實例對象:
復制代碼 代碼如下:
  var dogA = new DOG('大毛');
  var dogB = new DOG('二毛');

這兩個對象的species屬性是獨立的,修改其中一個,不會影響到另一個。
復制代碼 代碼如下:
  dogA.species = '貓科';
  alert(dogB.species); // 顯示"犬科",不受dogA的影響

每一個實例對象,都有自己的屬性和方法的副本。這不僅無法做到數據共享,也是極大的資源浪費。

所以:繼承的思想: 通過js特有的原型鏈來實現繼承機制!

四、基于原型鏈的繼承

1.直接繼承實現

復制代碼 代碼如下:
var Students = function(name, age, sid) {
    Person.call(this, name, age);
    this.sid = sid;
}
Students.prototype = new Person(); //把Person放到Students的原型鏈上實現繼承機制
Students.prototype.constructor = Students;
Students.prototype.getResults = function() {
    // 得到學生的成績
}

一定不要少了Students.prototype.constructor = Students這一行!,定義一個構造函數的時候,它默認的prototype是一個Object實例,然后prototype的constructor屬性自動被設置成該函數本身 ?。?!若手工將prototype設置為另一個對象的時候,則新對象自然不會具有原對象的contructor值,故需要重新設置其constructor屬性。如:
復制代碼 代碼如下:
var Test = function() {
    this.time = "now";
}
console.log(Test.prototype); // Object {} 一個空對象
console.log(Test.prototype.constructor); // function() {this.time = "now";},及函數本身
// 若手工改變Test的prototype屬性
Test.prototype = {
    someFunc: function() {
        console.log('hello world!');
    }
};
console.log(Test.prototype.constructor); // function Object() { [native code] }
// 然后你會發現完全指錯了,故手動更改prototype屬性的時候需要更改它的constructor指向;

經過上面的測試就知道為什么要修改constructor值了。

2.封裝繼承的函數extend

復制代碼 代碼如下:
function extend(subClass, superClass) {
    var F = function() {};
    F.prototype = superClass.prototype;
    subClass.prototype = new F();
    subClass.prototype.constructor = subClass;
}

其實這個函數的功能只是對上面繼承過程的一個封裝,不同的有:
只繼承了superClass的prototype屬性,并沒有繼承superClass構造函數中的屬性;
這樣做的優點在于:減少去new一個構造函數的開銷!
當然隨之的問題是不能單一的通過這個函數就能讓subClass繼承superClass的所有屬性
改進:
復制代碼 代碼如下:
// 在Students構造函數中繼續添加一行代碼:
Person.call(this, name, age);

五、小結

利用js的原型鏈原理,我們可以很容易的實現js的繼承機制,盡管不是非常的嚴格,但是我的目的達到了: 重復的代碼盡量出現一次!

希望本文所述對大家的javascript程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久热精品视频在线免费观看| 日韩av大片免费看| 日韩电影中文字幕在线| 国产成人精品久久二区二区| 国产一区二区视频在线观看| 久久久免费观看视频| 高清欧美性猛交xxxx黑人猛交| 国产一区二区三区在线观看网站| 欧美另类在线播放| 中文字幕亚洲激情| 色综合色综合网色综合| 精品亚洲国产成av人片传媒| 亚洲视频在线免费观看| 中文字幕少妇一区二区三区| 正在播放国产一区| 久久久免费精品| 日本欧美中文字幕| 久久中文字幕在线视频| 精品久久久久久久久久久久久久| 亚洲人成77777在线观看网| 日韩福利视频在线观看| 亚洲影院在线看| 亚洲精品日产aⅴ| 久久国产精品久久精品| 国产精品爱久久久久久久| 一色桃子一区二区| 视频在线观看一区二区| 久久久久久久久爱| 91九色单男在线观看| 91久久精品久久国产性色也91| 国产一区二区三区欧美| 国产欧美一区二区三区在线| 亚洲一区二区三区视频播放| 国产区精品在线观看| 91精品啪在线观看麻豆免费| 日韩高清电影免费观看完整| 欧美亚洲视频在线看网址| 岛国视频午夜一区免费在线观看| 亚洲人成网站免费播放| 日韩精品免费在线播放| 欧美中文字幕在线视频| 亚洲97在线观看| 欧美在线一区二区三区四| 亚洲在线免费视频| 北条麻妃一区二区在线观看| 国产欧美一区二区白浆黑人| 久久全球大尺度高清视频| 精品亚洲夜色av98在线观看| 国产一区二区欧美日韩| 亚洲一区二区三区四区视频| 国产精品亚洲综合天堂夜夜| 亚洲色图综合网| 欧美电影第一页| 国模精品视频一区二区三区| 欧美日韩成人精品| 日韩精品在线观看一区二区| 91成人在线观看国产| 久热国产精品视频| 久久久久久久999精品视频| 亚洲系列中文字幕| 久久久久久久网站| 欧美激情精品久久久久久久变态| 亚洲福利视频在线| 国产国语刺激对白av不卡| 欧美国产日韩精品| 久久久亚洲成人| 日韩在线免费视频观看| 黄色成人av网| 亚洲成人久久电影| 国产精品国模在线| 精品国产一区久久久| 最近2019中文字幕在线高清| 国产精品入口福利| 怡红院精品视频| 91成人在线视频| 欧美国产欧美亚洲国产日韩mv天天看完整| 91国内精品久久| 中文字幕欧美日韩va免费视频| 亚洲欧美一区二区激情| 91老司机在线| 日韩在线观看电影| 日韩精品中文字幕有码专区| 亚洲а∨天堂久久精品9966| 色播久久人人爽人人爽人人片视av| 国产精品视频26uuu| 国产日韩欧美在线| 成人精品久久av网站| xxx欧美精品| 欧美大片大片在线播放| 国产免费观看久久黄| 国产福利视频一区二区| 久久久久久国产免费| 日韩国产在线看| 社区色欧美激情 | 日本韩国欧美精品大片卡二| 91久久久久久| 亚洲在线视频福利| 国产一区二区三区免费视频| 97免费中文视频在线观看| 福利二区91精品bt7086| 色综合久综合久久综合久鬼88| 欧美精品激情在线| 88国产精品欧美一区二区三区| 少妇久久久久久| 成人精品网站在线观看| 亚洲人成网7777777国产| 亚洲а∨天堂久久精品喷水| 78m国产成人精品视频| www日韩中文字幕在线看| 国产一区二区丝袜| 国产成人精品久久二区二区| 国产亚洲欧美一区| 亚洲精品wwww| 日韩免费不卡av| 亚洲激情在线观看视频免费| 久久久精品网站| 精品亚洲国产成av人片传媒| 日本午夜人人精品| 2025国产精品视频| 97av在线影院| 成人欧美一区二区三区在线湿哒哒| 久久久精品欧美| 国产一级揄自揄精品视频| 日韩中文字幕网站| 97精品在线视频| 91精品国产高清久久久久久久久| 亚洲成人av中文字幕| 精品自在线视频| 91在线网站视频| 国产盗摄xxxx视频xxx69| 欧美成人精品激情在线观看| 日韩成人在线免费观看| 欧美在线免费观看| 亚洲美女性生活视频| 中文字幕亚洲一区二区三区| 亚洲最大激情中文字幕| 亚洲最新av在线网站| 国产欧美精品日韩精品| 国产日韩在线视频| 欧美性猛交xxxx黑人猛交| 成人欧美在线视频| 久久久亚洲国产天美传媒修理工| 日韩欧美有码在线| 久久久久久中文字幕| 最近2019好看的中文字幕免费| 国产精品扒开腿做| 欧美在线激情网| 69av成年福利视频| 欧美大学生性色视频| 国产自产女人91一区在线观看| 成人在线激情视频| 日韩精品免费一线在线观看| 91久久精品国产91久久性色| 久久免费视频在线| 亚洲人成免费电影| 亚洲经典中文字幕| 欧美日韩亚洲天堂| 欧美亚洲在线视频| 国产在线视频一区| 91高潮精品免费porn| 国产日韩一区在线| 国产精品wwwwww| 在线看福利67194| 日韩精品在线观看一区|