一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

FireFox JavaScript全局Event對象

而在FireFox中卻沒有這樣的對象,如果有函數嵌套調用,需要不停的向下傳遞Event,例如下面的場景。
復制代碼 代碼如下:
<div style="background-color:Red; width:300px; height:300px;" onclick="Test(event,this);" id="panel"></div>
function Test(event,dom){
Test1(event);
}
function Test1(event){
Test2(event);
}
function Test2(event){
alert(event.target.id);
}

在Test2方法中需要使用event,就需要寫成這樣。如果在某種場景下,比如添加新功能,需要修改原來的Test2方法,需要訪問event對象,而原來Test2方法的簽名是Test2(),沒有參數event,這時需要修改Test2()為Test2(event) 十分的不美觀,雖然JavaScript這樣的修改,是方法的重載,但是也破壞了原來的方法簽名。
在FireFox中是否有window.event這樣的全局變量來獲取event?
不幸的是FireFox的對象模型中是沒有的,但是可以使用變通的方法取得。例如:
復制代碼 代碼如下:
function GetEvent(caller){
if(document.all)
return window.event; //For IE.
if(caller == null || typeof(caller) != "function")
return null;
while(caller.caller != null){
caller = caller.caller;
}
return caller.arguments[0];
}

這里使用document.all判斷是否是IE瀏覽器的做法是不好的,應該使用UserAgent來判斷,JQuery等類庫中有好的實現。
這樣上面的 Test2方法就可以不用修改方法簽名了:
復制代碼 代碼如下:
function Test2(){
var event = GetEvent(Test2);
alert(GetEventTarget(event).id);
}
function GetEventTarget(event){
if(document.all)
return event.srcElement;
return event.target;
}

為什么可以寫出GetEvent方法,取得Event?
因為在Firefox的事件模型中最初的事件調用是將event顯示的傳遞給方法的,所以可以寫出GetEvent方法,取得喚起JavaScript的event。
Click to Open in New Window

JavaScript技術FireFox JavaScript全局Event對象,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 国内精品久久影院 | 一区二区三区鲁丝不卡麻豆 | 国产岛国 | 波多野结衣在线观看一区二区三区 | 91久久精品视频 | 在线观看视频一区二区三区 | 午夜爽视频 | 黑人www| 亚色中文字幕 | 六月天婷婷 | 国产精品美女久久久久网站 | 一个人免费播放在线视频看片 | 亚洲成人中文 | 久夜色精品国产一区二区三区 | 美女裸体自慰在线观看 | 久久99草| 91九色视频| 色综合色狠狠天天久久婷婷基地 | 国产亚洲欧洲国产综合一区 | 国产精品丝袜高跟鞋 | 国产欧美一区二区三区观看 | 一本色道久久综合狠狠躁 | 一区二区三区日韩精品 | 97精品国产91久久久久久久 | 国产精品国色综合久久 | 色综合久久88一加勒比 | 久久午夜夜伦伦鲁鲁片 | 欧美日韩激情一区二区三区 | 韩国精品一区二区三区四区五区 | 国产在线视频色综合 | 色女人综合网 | 福利在线小视频 | 看全色黄大色黄大片大学生 | 中文字幕在线观看一区二区三区 | 国语精品视频在线观看不卡 | 特大巨黑吊在线播放 | 国产真实伦视频在线视频 | 在线视频 91 | 国产精品美女一区二区 | 成 人 黄 色 视频播放165 | 国产夫妻久久 |