驗證javascript中Object和Function的關系的三段簡單代碼
更新時間:2010年06月27日 02:35:29 作者:
今天重溫經(jīng)典書籍。這一次看的是博客園李戰(zhàn)老師寫的<<悟透JavaScript>>,也是被樓豬翻看最多的技術(shù)書籍之一。
話說在樓豬理解和實踐能力尚欠火候的時候,在這篇里曾經(jīng)照搬了李戰(zhàn)老師不少東西寫在自己的博客里作為“知識儲備”。這一次還是不能免俗。在翻到第5章的時候,被開篇第二段話深深吸引和折服:“函數(shù)具有對象的全部特征,你完全可以把函數(shù)當對象調(diào)用。其實,函數(shù)就是對象,只不過比一般的對象多了一個括號“{}”操作符,這個操作符用來執(zhí)行函數(shù)的邏輯,即函數(shù)本身還可以被調(diào)用,一般對象卻不可以被調(diào)用,除此之外完全相同”。寥寥數(shù)語,卻深刻闡釋了對象和函數(shù)的關系。下面樓豬就通過自己寫的幾段簡單代碼,論證一下javascript內(nèi)置Object和Function的關系。
1、Function就是Object,Object就是Function
alert(Function instanceof Object); // true
alert(Object instanceof Function); // true
如你所看到的那樣,通過instanceof操作符,函數(shù)就是對象,對象就是函數(shù)。
2、既然1是成立的,那么Function擴展的原型方法,Object能“得到”嗎?
alert(Object.funcMethod); // undefined
Function.prototype.funcMethod = function() {
/*some function method code here*/
}
alert(Function.funcMethod);
alert(Object.funcMethod);
alert(Function.funcMethod === Object.funcMethod); //true
你沒有看錯,我們?yōu)镕unction擴展的原型方法funcMethod,Object實現(xiàn)了神奇的“不勞而獲”。
3、既然1和2都成立,那么Object擴展的原型方法,F(xiàn)unction能“得到”嗎?!
代碼
alert(Function.objMethod); // undefined
Object.prototype.objMethod = function() {
/*some object method code here*/
}
alert(Object.objMethod);
alert(Function.objMethod);
alert(Function.objMethod === Object.objMethod); //true or false?
上面代碼中最后有個問號的那一行是彈出true還是false呢?賣個關子,根據(jù)樓豬通篇直白而單純的表述,你應該已經(jīng)知道結(jié)果了,這里不公布答案了。
最后,容樓豬在這里得意地自戀一下:個人認為上面這三段代碼應該比原書中驗證“函數(shù)就是對象的本質(zhì)”的代碼更具有說服力。
1、Function就是Object,Object就是Function
復制代碼 代碼如下:
alert(Function instanceof Object); // true
alert(Object instanceof Function); // true
如你所看到的那樣,通過instanceof操作符,函數(shù)就是對象,對象就是函數(shù)。
2、既然1是成立的,那么Function擴展的原型方法,Object能“得到”嗎?
復制代碼 代碼如下:
alert(Object.funcMethod); // undefined
Function.prototype.funcMethod = function() {
/*some function method code here*/
}
alert(Function.funcMethod);
alert(Object.funcMethod);
alert(Function.funcMethod === Object.funcMethod); //true
你沒有看錯,我們?yōu)镕unction擴展的原型方法funcMethod,Object實現(xiàn)了神奇的“不勞而獲”。
3、既然1和2都成立,那么Object擴展的原型方法,F(xiàn)unction能“得到”嗎?!
代碼
復制代碼 代碼如下:
alert(Function.objMethod); // undefined
Object.prototype.objMethod = function() {
/*some object method code here*/
}
alert(Object.objMethod);
alert(Function.objMethod);
alert(Function.objMethod === Object.objMethod); //true or false?
上面代碼中最后有個問號的那一行是彈出true還是false呢?賣個關子,根據(jù)樓豬通篇直白而單純的表述,你應該已經(jīng)知道結(jié)果了,這里不公布答案了。
最后,容樓豬在這里得意地自戀一下:個人認為上面這三段代碼應該比原書中驗證“函數(shù)就是對象的本質(zhì)”的代碼更具有說服力。
相關文章
sencha touch 模仿tabpanel導航欄TabBar的實例代碼
這篇文章介紹了sencha touch 模仿tabpanel導航欄TabBar的實例代碼,有需要的朋友可以參考一下2013-10-10
javascript前端和后臺進行數(shù)據(jù)交互方法示例
這篇文章主要介紹了javascript前端和后臺進行數(shù)據(jù)交互方法示例,文章通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-08-08
JavaScript中window和document用法詳解
這篇文章主要介紹了JavaScript中window和document用法詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-07-07

