驗證javascript中Object和Function的關系的三段簡單代碼
更新時間:2010年06月27日 02:35:29 作者:
今天重溫經(jīng)典書籍。這一次看的是博客園李戰(zhàn)老師寫的<<悟透JavaScript>>,也是被樓豬翻看最多的技術書籍之一。
話說在樓豬理解和實踐能力尚欠火候的時候,在這篇里曾經(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)知道結果了,這里不公布答案了。
最后,容樓豬在這里得意地自戀一下:個人認為上面這三段代碼應該比原書中驗證“函數(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)知道結果了,這里不公布答案了。
最后,容樓豬在這里得意地自戀一下:個人認為上面這三段代碼應該比原書中驗證“函數(shù)就是對象的本質(zhì)”的代碼更具有說服力。
相關文章
JavaScript 上傳文件(psd,壓縮包等),圖片,視頻的實現(xiàn)方法
本文通過實例代碼給大家介紹了JavaScript 上傳文件(psd,壓縮包等),圖片,視頻功能,需要的朋友可以參考下2017-06-06JS實現(xiàn)側邊欄鼠標經(jīng)過彈出框+緩沖效果
本文主要介紹了JS實現(xiàn)側邊欄鼠標經(jīng)過彈出框+緩沖效果的實現(xiàn)原理與方法步驟。具有很好的參考價值,下面跟著小編一起來看下吧2017-03-03