今天看了一本叫《JQuery實戰》的書,直接奔最後的附錄(JavaScript必知必會),看完了才發現自己對JavaScript有很大的誤解,因為自己以前用的是Java和現在用的C#都多多少少影響了自己的思維,並且文法的魔法更幹擾了我的理解,所以,指出來,讓大家也好理解。
JavaScript函數被認為是對象,與其他JavaScript物件類型一樣,比如String,Number,Date。函數也是由JavaScript構造器來定義。所以也有稱函數是一等對象。舉個例子:平時我們是這樣寫的,function doSomethingWonderful(){<br />alert('does something wonderful');<br />}但是我們可以這樣寫協助理解上面的話,doSomethingWonderful = function(){<br />alert('does something wonderful');<br />}這個意思是把函數指派給頂層變數(window的屬性)。
讓我們再看更深入的,同時把this引進來說明,var o1 = { handle:'01' };<br />var o2 = { handle:'02' };<br />var o3 = { handle:'03' };<br />window.handle = 'window';<br />function whoAmI(){<br />return this.handle;<br />}<br />o1.identifyMe = whoAmI;<br />alert(whoAmI());<br />alert(o1.identifyMe());<br />alert(whoAmI.call(o2));<br />alert(whoAmI.apply(o3));
答案是什麼我想你們都猜到了(window,o1,o2,o3),在這裡要注意的就是this在函數的上下文裡指的是什麼。調用call()和apply(),讓函數表現的像是o2的方法,但其實這個函數和o2沒有任何關聯(連o2的屬性都不是)。