欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

javascript繼承機制實例詳解

 更新時間:2014年11月20日 09:18:40   投稿:shichen2014  
這篇文章主要介紹了javascript繼承機制,以實例形式詳細分析了javascript繼承的原理與基于原型鏈的繼承實現(xiàn)方法,具有不錯的參考借鑒價值,需要的朋友可以參考下

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

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

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

一、如何創(chuàng)建一個類

假設有給叫Person的類如下:

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

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

二、換成js如何能做到

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

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

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

舉例來說,現(xiàn)在有一個叫做DOG的構造函數(shù),表示狗對象的原型。

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

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

注意構造函數(shù)中的this關鍵字,它就代表了新創(chuàng)建的實例對象。

三、new運算符的缺點

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

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

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

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

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

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

四、基于原型鏈的繼承

1.直接繼承實現(xiàn)

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

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

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

2.封裝繼承的函數(shù)extend

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

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

五、小結

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

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

相關文章

  • 一個很Cool的JS菜單效果

    一個很Cool的JS菜單效果

    [藍色]一個很Cool的JS菜單效果...
    2006-09-09
  • XHTML-Strict 內允許出現(xiàn)的標簽

    XHTML-Strict 內允許出現(xiàn)的標簽

    XHTML-Strict 內允許出現(xiàn)的標簽...
    2006-12-12
  • js常用方法示例梳理(總結篇)

    js常用方法示例梳理(總結篇)

    這篇文章主要為大家介紹了js常用的方法示例梳理總結及功能詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-05-05
  • 獲取客戶端網(wǎng)卡MAC地址和IP地址實現(xiàn)JS代碼

    獲取客戶端網(wǎng)卡MAC地址和IP地址實現(xiàn)JS代碼

    獲取客戶端的一些信息,如IP和MAC,以結合身份驗證,相信很多人都會這樣做吧,我們這里用Javascript,這樣做的好處是不需要服務器端進行處理,有客戶端自行獲取,感興趣的你可以參考下哈
    2013-03-03
  • 使用Xcache緩存器加速PHP網(wǎng)站的配置方法

    使用Xcache緩存器加速PHP網(wǎng)站的配置方法

    由于國內網(wǎng)站備案比較麻煩,所以筆者便把網(wǎng)站放到了香港。雖然網(wǎng)站免去了備案的困擾,但是從訪問速度上來看,一般要比放于國內的網(wǎng)站慢2-3倍,所以便想辦法對網(wǎng)站做了一些簡單的優(yōu)化,比如使用緩存系統(tǒng)來提升網(wǎng)站頁面訪問速度
    2017-04-04
  • 了解一點js的Eval函數(shù)

    了解一點js的Eval函數(shù)

    之前只知道eval可以解析字符串,剛剛網(wǎng)上看了又了解了一點,這里貼出來,不懂的也看看哈
    2012-07-07
  • js的表單操作 簡單計算器

    js的表單操作 簡單計算器

    javascript寫的簡單的加減乘除計算器,里面涉及到一些方法還是很實用的哦,新手不要錯過
    2011-12-12
  • JS實現(xiàn)圖片預加載之無序預加載功能代碼

    JS實現(xiàn)圖片預加載之無序預加載功能代碼

    這篇文章主要介紹了JS實現(xiàn)圖片預加載之無序預加載功能代碼,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2017-05-05
  • NodeJS 模塊開發(fā)及發(fā)布詳解分享

    NodeJS 模塊開發(fā)及發(fā)布詳解分享

    NodeJS 是一門年輕的語言,擴展模塊并不太全,經(jīng)常我們想用某個模塊但是卻找不到合適的
    2012-03-03
  • 微信小程序提交form操作示例

    微信小程序提交form操作示例

    這篇文章主要介紹了微信小程序提交form操作,結合實例形式分析了微信小程序開發(fā)中使用form組件實現(xiàn)數(shù)據(jù)提交與數(shù)據(jù)處理相關操作技巧,需要的朋友可以參考下
    2018-12-12

最新評論