在 ES6 中,定義匿名類別的能力為類別聲明提供了語法糖。雖然很方便,但立即實例化此類類別可能會導致大量問題。
當立即實例化匿名類別時,JavaScript 會建立一個新的建構子並動態原型物件。表達式的每次求值都會產生不同的建構子和原型。
這種做法有幾個明顯的缺點:
缺乏可重用性:
與命名類不同,立即實例化的匿名類別每次都會創建一個新的建構子和原型。這意味著多個實例不會共享相同的原型,失去了類別繼承和原型共享的好處。
單例謬誤:
如果使用此模式背後的意圖是創建單例對象,它會失敗。建構函式仍然可訪問,允許使用新的entity.constructor建立多個實例。
共識很明確:應避免立即實例化匿名類別。簡單的物件字面量提供了更有效率、更直接的替代方案:
var entity = { name: 'Foo', getName: function() { return this.name; } };
雖然新的類別模式在其他一些語言中是可以接受的,但它在 JavaScript 中的行為有所不同。 JavaScript 類別所創建的動態本質排除了這些語言所享有的優勢。
免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。
Copyright© 2022 湘ICP备2022001581号-3