js 事件處理函數(shù)間的Event物件是否全等
更新時(shí)間:2011年04月08日 00:03:33 作者:
在非IE,事件對象Propagation之間的處理函數(shù),或同dom節(jié)點(diǎn)觸發(fā)的多個(gè)函數(shù)之間的Event物件是全等的。與綁定形式[addEventListener/DOM0]無關(guān)。
這個(gè)小問題以前就遇到,卻沒有去總結(jié)
現(xiàn)在又遇到,為了得到準(zhǔn)確結(jié)論,記錄下來:
如題:同一事件 多個(gè)執(zhí)行函數(shù)間的Event物件是否全等
例如:
dom.addEvent('click',fna);
dom.addEvent('click',fnb);
1:在fna里對Event物件添加的屬性,在其后執(zhí)行的fnb函數(shù)里是對于Event物件是否能訪問到?
2:執(zhí)行fna/fnb函數(shù)時(shí)的Event物件是否全等 Eventfna===Eventfnb ?
標(biāo)準(zhǔn)的文檔太長哪里是說明了這里的規(guī)則呢?懶吧...
對于Jquery,同一事件,多個(gè)執(zhí)行函數(shù)間的Event物件是全等的。
Jquery live綁定事件的實(shí)現(xiàn)里,對于可能會(huì)被重復(fù)執(zhí)行的函數(shù)liveHandler,依靠額外給Event物件的liveFired屬性,使得在第一次之后執(zhí)行的liveHandler 的開始 即退出函數(shù):
if (event.liveFired === this || ...) {
return;
}
///....
event.liveFired = this;
測試:
function a(e) {
e.abc = function() {
alert(a);
};
prevEvent = e;
prevIeEvent=window.event;
}
function b(e,event) {
e.abc(); //fn
alert(e === prevEvent); //true
if(event=window.event){
alert(event===e); //false
alert(event===prevIeEvent);//false
alert(event===prevEvent);//false
}
}
var t = document.getElementById("p");
if (t.addEventListener) {
t.addEventListener('click', a, false);
t.addEventListener('click', b, false)
} else {
t.attachEvent('onclick', b);
t.attachEvent('onclick', a)
}
對于原生綁定事件方式[addEventListener,attachEvent],對于多個(gè)執(zhí)行函數(shù)間的Event物件(通過參數(shù)傳遞的event)是全等的,在IE里,通過window.event形式得到的Event物件不全等。與通過參數(shù)傳遞的Event也不全等。
對于冒泡事件:
dom.addEvent('click',fna);
domParentNode.addEvent('click',fnb);
jquery里,在以trigger形式觸發(fā)事件時(shí),冒泡事件之間的函數(shù)中的Event物件是全等的。而實(shí)際用戶行為觸發(fā)的事件,則不是同一物件。自定義屬性也傳遞不了。取值設(shè)置都都沒有影響真正的originalEvent。
以原生綁定事件方式[addEventListener,attachEvent]:
function a(e) {
e.abc = function() {
alert(a);
};
prevEvent = e;
prevIeEvent=window.event;
}
function b(e,event) {
alert(e.abc); //fn
alert(e === prevEvent); //true
if(event=window.event){
alert(event===e); //false
alert(event===prevIeEvent);//false
alert(event===prevEvent);//false
}
}
var t = document.getElementById("p");
if (t.addEventListener) {
t.addEventListener('click', a, false);
document.body.addEventListener('click', b, false);
} else {
t.attachEvent('onclick', a);
document.body.attachEvent('onclick', b);
}
結(jié)果是attachEvent綁定事件時(shí)IE中冒泡事件之間的函數(shù)內(nèi)Event物件不一致。FF等 以addEventListener 則全等對象。
事實(shí)上,在非IE,事件對象Propagation之間的處理函數(shù),或同dom節(jié)點(diǎn)觸發(fā)的多個(gè)函數(shù)之間的Event物件是全等的。與綁定形式[addEventListener/DOM0]無關(guān)。
而在IE,僅同dom節(jié)點(diǎn)觸發(fā)的多個(gè)函數(shù)之間的通過參數(shù)傳遞的Event物件(attachEvent)是全等的。
現(xiàn)在又遇到,為了得到準(zhǔn)確結(jié)論,記錄下來:
如題:同一事件 多個(gè)執(zhí)行函數(shù)間的Event物件是否全等
例如:
復(fù)制代碼 代碼如下:
dom.addEvent('click',fna);
dom.addEvent('click',fnb);
1:在fna里對Event物件添加的屬性,在其后執(zhí)行的fnb函數(shù)里是對于Event物件是否能訪問到?
2:執(zhí)行fna/fnb函數(shù)時(shí)的Event物件是否全等 Eventfna===Eventfnb ?
標(biāo)準(zhǔn)的文檔太長哪里是說明了這里的規(guī)則呢?懶吧...
對于Jquery,同一事件,多個(gè)執(zhí)行函數(shù)間的Event物件是全等的。
Jquery live綁定事件的實(shí)現(xiàn)里,對于可能會(huì)被重復(fù)執(zhí)行的函數(shù)liveHandler,依靠額外給Event物件的liveFired屬性,使得在第一次之后執(zhí)行的liveHandler 的開始 即退出函數(shù):
復(fù)制代碼 代碼如下:
if (event.liveFired === this || ...) {
return;
}
///....
event.liveFired = this;
測試:
復(fù)制代碼 代碼如下:
function a(e) {
e.abc = function() {
alert(a);
};
prevEvent = e;
prevIeEvent=window.event;
}
function b(e,event) {
e.abc(); //fn
alert(e === prevEvent); //true
if(event=window.event){
alert(event===e); //false
alert(event===prevIeEvent);//false
alert(event===prevEvent);//false
}
}
var t = document.getElementById("p");
if (t.addEventListener) {
t.addEventListener('click', a, false);
t.addEventListener('click', b, false)
} else {
t.attachEvent('onclick', b);
t.attachEvent('onclick', a)
}
對于原生綁定事件方式[addEventListener,attachEvent],對于多個(gè)執(zhí)行函數(shù)間的Event物件(通過參數(shù)傳遞的event)是全等的,在IE里,通過window.event形式得到的Event物件不全等。與通過參數(shù)傳遞的Event也不全等。
對于冒泡事件:
復(fù)制代碼 代碼如下:
dom.addEvent('click',fna);
domParentNode.addEvent('click',fnb);
jquery里,在以trigger形式觸發(fā)事件時(shí),冒泡事件之間的函數(shù)中的Event物件是全等的。而實(shí)際用戶行為觸發(fā)的事件,則不是同一物件。自定義屬性也傳遞不了。取值設(shè)置都都沒有影響真正的originalEvent。
以原生綁定事件方式[addEventListener,attachEvent]:
復(fù)制代碼 代碼如下:
function a(e) {
e.abc = function() {
alert(a);
};
prevEvent = e;
prevIeEvent=window.event;
}
function b(e,event) {
alert(e.abc); //fn
alert(e === prevEvent); //true
if(event=window.event){
alert(event===e); //false
alert(event===prevIeEvent);//false
alert(event===prevEvent);//false
}
}
var t = document.getElementById("p");
if (t.addEventListener) {
t.addEventListener('click', a, false);
document.body.addEventListener('click', b, false);
} else {
t.attachEvent('onclick', a);
document.body.attachEvent('onclick', b);
}
結(jié)果是attachEvent綁定事件時(shí)IE中冒泡事件之間的函數(shù)內(nèi)Event物件不一致。FF等 以addEventListener 則全等對象。
事實(shí)上,在非IE,事件對象Propagation之間的處理函數(shù),或同dom節(jié)點(diǎn)觸發(fā)的多個(gè)函數(shù)之間的Event物件是全等的。與綁定形式[addEventListener/DOM0]無關(guān)。
而在IE,僅同dom節(jié)點(diǎn)觸發(fā)的多個(gè)函數(shù)之間的通過參數(shù)傳遞的Event物件(attachEvent)是全等的。
相關(guān)文章
JavaScript鼠標(biāo)移動(dòng)事件以及實(shí)戰(zhàn)案例
在學(xué)習(xí)JS中我對鼠標(biāo)移動(dòng)事件進(jìn)行了一些總結(jié),需要的可以作參考,下面這篇文章主要給大家介紹了關(guān)于JavaScript鼠標(biāo)移動(dòng)事件以及實(shí)戰(zhàn)案例的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-05-05
js跳轉(zhuǎn)到指定url的方法與實(shí)際使用
這篇文章主要給大家介紹了關(guān)于js跳轉(zhuǎn)到指定url的方法與實(shí)際使用的相關(guān)資料,要實(shí)現(xiàn)JavaScript跳轉(zhuǎn)到指定URL,可以使用window.location對象來實(shí)現(xiàn),需要的朋友可以參考下2023-09-09
原生JS檢測CSS3動(dòng)畫是否結(jié)束的方法詳解
這篇文章主要介紹了原生JS檢測CSS3動(dòng)畫是否結(jié)束的方法,結(jié)合實(shí)例形式分析了javascript事件響應(yīng)及針對css3屬性檢測相關(guān)操作技巧,需要的朋友可以參考下2019-01-01
layui(1.0.9)文件上傳upload,前后端的實(shí)例代碼
今天小編就為大家分享一篇layui(1.0.9)文件上傳upload,前后端的實(shí)例代碼,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-09-09
微信小程序訂閱消息(java后端實(shí)現(xiàn))開發(fā)
這篇文章主要介紹了微信小程序訂閱消息(java后端實(shí)現(xiàn))開發(fā),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-06-06

