首頁  >  文章  >  web前端  >  javaScript物件導向繼承方法經典實作_基礎知識

javaScript物件導向繼承方法經典實作_基礎知識

WBOY
WBOY原創
2016-05-16 17:24:57922瀏覽

JavaScript的出現已經將近20多年了,但對這個預言的褒貶還是眾說紛紜。很多人都說JavaScript不能算是物件導向的變成語言。但是JavaScript的型別非常鬆散,也沒有編譯器。這樣一來給了程式設計師很大的自由,也帶來了一些缺陷。

雖然JavaScript不算是一門物件導向的語言。但是我們可以模仿其他語言實現物件導向的方式來實作JavaScript的面向程式設計。

以下是JavaScript教學中非常經典的繼承方法。

複製程式碼 程式碼如下:

//定義一個Pet物件。通過這一個名稱和數量的腿。
var Pet = function (name,legs) {
this.name = name; //Save ths name and legs values.
this.legs = legs;
};

//創建一個方法,顯示了Pet的名字和數量的腿。
Pet.prototype.getDetails = function () {
return this.name " has " this.legs " legs ";
}

//定義一個Cat物件,繼承從Pet 。
var Cat = function (name) {
Pet.call(this,name,4); //呼叫這個父物件的建構子
};

//這條線執行繼承從Pet。
Cat.prototype = new Pet();

//增加動作方法的貓
Cat.prototype.action = function () {
return "Catch a bird";
};

//建立一個實例petCat的貓。
var petCat = new Cat("felix");

var details = petCat.getDetails();
console.log(details) //"felix has 4 legs".
var action = petCat.action();
console.log(action) //"Catch a bird".
petCat.name = "sylvester"; //改變petCat的名字
petCat.legs = 7; //改變petCat腿的數量
details = petCat.getDetails();
console.log(details) //"sylvester has 7 legs".

上述方法執行起來沒有太大的問題,但是程式碼整體風格略顯臃腫,並不很優雅。在外面還是可以對屬性進行修改。這種方法沒有對繼承的屬性進行保護。下面一種方法,省去的new和prototype,利用「函數繼承」的特性實作。
複製程式碼 程式碼如下:

//定義一個pet物件。通過這一個名稱和數量的腿。
var pet = function (name,legs) {
//創造一個物件that,其中名字是可以改的,但是腿數不可以改,實現了變數私有化。
var that = {
name : name,
getDetails : function () {
return that.name " has " legs " legs ";
}
}
}
;
return that;
}

//定義一個cat物件,繼承從pet。
var cat = function (name) {
var that = pet(name,4); //從pet繼承屬性

//cat增加一個action的方法。
that.action = function () {
return "Catch a bird";
}

return that;

}

//創建一個petCat2;
var petCat2 = cat("Felix");

var details = petCat2.getDetails();
console.log(details) //"felix has 4 legs".
var action = petCat2.action();
console.log(action) //"Catch a bird".
petCat2.name = "sylvester"; //我們可以改名。
petCat2.legs = 7; //但是不可以改變腿的數量
details = petCat2.getDetails();
console.log(details) //"sylvester has 4 legs".


溫馨提示:使用原型繼承的好處是記憶體效率高,不管它被繼承多少次,物件的原型屬性和方法只被保存一次。函數繼承的時候,每個新的實例都會建立重複的屬性和方法。若創建很多大的對象,記憶體消耗會很大。解決方法是把較大的屬性或方法保存在一個物件中,並將其作為參數傳給建構子。這樣所有實例就會使用一個物件資源,而不是創建自己的版本了。
上面兩種方法都可以輕鬆實現JavaScript物件導向的繼承,沒有哪一種方法絕對的好,也沒有哪一種方法絕對的不好。依個人情況喜好而定。這兩種方法也不是唯一的,歡迎大家評論補充喲!~
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn