深入理解javascript原型和閉包(7)——原型的靈活性

王福朋發表於2014-09-18

在Java和C#中,你可以簡單的理解class是一個模子,物件就是被這個模子壓出來的一批一批月餅(中秋節剛過完)。壓個啥樣,就得是個啥樣,不能隨便動,動一動就壞了。

而在javascript中,就沒有模子了,月餅被換成了麵糰,你可以捏成自己想要的樣子。

 

首先,物件屬性可以隨時改動。

物件或者函式,剛開始new出來之後,可能啥屬性都沒有。但是你可以這會兒加一個,過一會兒在加兩個,非常靈活。

在jQuery的原始碼中,物件被建立時什麼屬性都沒有,都是程式碼一步一步執行時,一個一個加上的。

 

其次,如果繼承的方法不合適,可以做出修改。

如上圖,Object和Array的toString()方法不一樣。肯定是Array.prototype.toString()方法做了修改。

同理,我也可以自定義一個函式,並自己去修改prototype.toString()方法。

 

最後,如果感覺當前缺少你要用的方法,可以自己去建立。

例如在json2.js原始碼中,為Date、String、Number、Boolean方法新增一個toJSON的屬性。

如果你要新增內建方法的原型屬性,最好做一步判斷,如果該屬性不存在,則新增。如果本來就存在,就沒必要再新增了。

---------------------------------------------------------------------------

本文已更新到《深入理解javascript原型和閉包系列》的目錄,更多內容可參見《深入理解javascript原型和閉包系列》。

另外,歡迎關注我的微博

學習作者教程:《前端JS高階面試》《前端JS基礎面試題》《React.js模擬大眾點評webapp》《zepto設計與原始碼分析》《json2.js原始碼解讀

相關文章