|
1、Function就是Object,Object就是Function
復制代碼 代碼如下:
alert(Function instanceof Object); // true
alert(Object instanceof Function); // true
如你所看到的那樣,通過instanceof操作符,函數就是對象,對象就是函數。
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
你沒有看錯,我們為Function擴展的原型方法funcMethod,Object實現了神奇的“不勞而獲”。
3、既然1和2都成立,那么Object擴展的原型方法,Function能“得到”嗎?!
代碼
復制代碼 代碼如下:
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呢?賣個關子,根據樓豬通篇直白而單純的表述,你應該已經知道結果了,這里不公布答案了。
最后,容樓豬在這里得意地自戀一下:個人認為上面這三段代碼應該比原書中驗證“函數就是對象的本質”的代碼更具有說服力。
JavaScript技術:驗證javascript中Object和Function的關系的三段簡單代碼,轉載需保留來源!
鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。