js對(duì)于函數(shù)的定義是非常松,即使你在函數(shù)定義時(shí)未寫任何參數(shù),或者你定義的參數(shù)有多個(gè),但是你調(diào)用時(shí),一個(gè)參數(shù)也不填,也不會(huì)出錯(cuò)的。
因?yàn)閖s函數(shù)內(nèi)默認(rèn)有個(gè)變量,保存你的入?yún)⒔校篴rguments,
他是一個(gè)數(shù)組,下標(biāo)從0開始,
所以獲取event可以寫成
function eventTest(){
var event = window.event||arguments[0];
//target 就是這個(gè)對(duì)象
target = event.srcElement||event.target,
//這個(gè)對(duì)象的值
targetValue = target.value;
}
當(dāng)然,有的時(shí)候需要給函數(shù)傳入幾個(gè)參數(shù),這時(shí)如果要用想用到event的話可以這么寫
function eventTest(a,b){
var event = window.event || arguments.callee.caller.arguments[0]
//target 就是這個(gè)對(duì)象
target = event.srcElement||event.target,
//這個(gè)對(duì)象的值
targetValue = target.value;
}
如果傳入了參數(shù)卻如第一種寫法的話,則arguments中將會(huì)傳入傳入的參數(shù),這時(shí)獲取的arguments[0]就會(huì)是第一個(gè)傳入的參數(shù)了。
鑒于此,故還是都用第二中方法獲取更為穩(wěn)妥。
|