了解 JavaScript 中的原型共享:從原型繼承的物件
在 JavaScript 中,物件從其原型繼承屬性。需要考慮的一個面向是定義為原型屬性的陣列在類別實例中的行為方式。
據觀察,原型陣列不是單一類別實例私有的,而是在所有實例之間共用。出現這種行為是因為物件的原型充當物件本身。原型屬性由從該特定原型派生的所有物件共用。
考慮以下範例:
function Sandwich() { // Uncomment this to fix the problem //this.ingredients = []; } Sandwich.prototype = { "ingredients" : [], "addIngredients" : function( ingArray ) { for( var key in ingArray ) { this.addIngredient( ingArray[ key ] ); } }, "addIngredient" : function( thing ) { this.ingredients.push( thing ); } }
在此範例中,名為「ingredients」的陣列被定義為「三明治」功能。如果「this.ingredients = [];」在建構函式中被註解掉,會發生以下行為:
當建立「Sandwich」的新實例(例如「cheeseburger」或「blt」)時,這些實例最初繼承來自的“ingredients”數組原型。對此數組進行的修改(例如在“起司漢堡”中添加成分)也會影響所有其他“三明治”實例的“成分”數組。這種共享行為是由於所有實例都引用相同的數組而不是單獨的副本這一事實而產生的。
要解決此問題並為每個實例創建單獨的數組,必須在構造函數中定義“ingredients”數組:
function Sandwich() { this.ingredients = []; }
此修改在構造過程中為“三明治”的每個實例分配一個新數組,確保對「成分」數組所做的任何更改都有效特定於實例。
總之,定義為原型屬性的陣列在繼承該原型的所有物件之間共用。要建立特定於實例的資料(例如陣列),必須在建構函數中定義它們。這種理解對於在 JavaScript 中有效使用繼承和物件導向程式設計至關重要。
以上是為什麼 JavaScript 中的原型陣列在類別實例之間共用?的詳細內容。更多資訊請關注PHP中文網其他相關文章!