国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

FireFox JavaScript全局Event對象

2019-11-21 01:19:22
字體:
供稿:網(wǎng)友
而在FireFox中卻沒有這樣的對象,如果有函數(shù)嵌套調(diào)用,需要不停的向下傳遞Event,例如下面的場景。
復(fù)制代碼 代碼如下:

<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(),沒有參數(shù)event,這時需要修改Test2()為Test2(event) 十分的不美觀,雖然JavaScript這樣的修改,是方法的重載,但是也破壞了原來的方法簽名。
在FireFox中是否有window.event這樣的全局變量來獲取event?
不幸的是FireFox的對象模型中是沒有的,但是可以使用變通的方法取得。例如:
復(fù)制代碼 代碼如下:

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瀏覽器的做法是不好的,應(yīng)該使用UserAgent來判斷,JQuery等類庫中有好的實現(xiàn)。
這樣上面的 Test2方法就可以不用修改方法簽名了:
復(fù)制代碼 代碼如下:

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的事件模型中最初的事件調(diào)用是將event顯示的傳遞給方法的,所以可以寫出GetEvent方法,取得喚起JavaScript的event。
Click to Open in New Window
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 西城区| 沅江市| 霍州市| 施甸县| 罗源县| 巴林右旗| 高州市| 安宁市| 广安市| 镇沅| 哈密市| 腾冲县| 牟定县| 英山县| 怀柔区| 德格县| 巨鹿县| 河间市| 兰坪| 无锡市| 郯城县| 青岛市| 通河县| 德化县| 西青区| 武义县| 天柱县| 武邑县| 黔南| 晋中市| 根河市| 镶黄旗| 张北县| 寿阳县| 商南县| 茶陵县| 靖西县| 怀仁县| 滦南县| 济南市| 东兰县|