在 ES6 中,定義匿名類別的能力為類別聲明提供了語法糖。雖然很方便,但立即實例化此類類別可能會導致大量問題。
當立即實例化匿名類別時,JavaScript 會建立一個新的建構子並動態原型物件。表達式的每次求值都會產生不同的建構子和原型。
這種做法有幾個明顯的缺點:
缺乏可重用性:
與命名類不同,立即實例化的匿名類別每次都會創建一個新的建構子和原型。這意味著多個實例不會共享相同的原型,從而失去了類別繼承和原型共享的好處。
單例謬誤:
如果使用此模式背後的意圖是建立單例對象,它會失敗。建構函式仍然可訪問,允許使用新的entity.constructor建立多個實例。
共識很明確:應避免立即實例化匿名類別。簡單的物件字面量提供了更有效率、更直接的替代方案:
var entity = { name: 'Foo', getName: function() { return this.name; } };
雖然新的類別模式在其他一些語言中是可以接受的,但它在JavaScript 中的行為有所不同。 JavaScript 類別所創建的動態本質排除了這些語言所享有的優勢。
以上是在 ES6 中立即實例化匿名類別是一個壞主意嗎?的詳細內容。更多資訊請關注PHP中文網其他相關文章!