欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

js事件監(jiān)聽器用法實(shí)例詳解

 更新時(shí)間:2015年06月01日 11:55:18   作者:天使小寶  
這篇文章主要介紹了js事件監(jiān)聽器用法,以實(shí)例形式較為詳細(xì)的分析了javascript事件監(jiān)聽器使用注意事項(xiàng)與相關(guān)技巧,需要的朋友可以參考下

本文實(shí)例講述了js事件監(jiān)聽器用法。分享給大家供大家參考。具體分析如下:

1、當(dāng)同一個(gè)對(duì)象使用.onclick的寫法觸發(fā)多個(gè)方法的時(shí)候,后一個(gè)方法會(huì)把前一個(gè)方法覆蓋掉,也就是說,在對(duì)象的onclick事件發(fā)生時(shí),只會(huì)執(zhí)行最后綁定的方法。而用事件監(jiān)聽則不會(huì)有覆蓋的現(xiàn)象,每個(gè)綁定的事件都會(huì)被執(zhí)行。如下:

window.onload = function(){ 
 var btn = document.getElementById("yuanEvent"); 
 btn.onclick = function(){ 
  alert("第一個(gè)事件"); 
 } 
 btn.onclick = function(){ 
  alert("第二個(gè)事件"); 
 } 
 btn.onclick = function(){ 
  alert("第三個(gè)事件"); 
 } 
}

最后只輸出:第三個(gè)事件,因?yàn)楹笠粋€(gè)方法都把前一個(gè)方法覆蓋掉了。

原生態(tài)的事件綁定函數(shù)addEventListener:

var eventOne = function(){ 
 alert("第一個(gè)監(jiān)聽事件"); 
} 
function eventTwo(){ 
 alert("第二個(gè)監(jiān)聽事件"); 
} 
window.onload = function(){ 
 var btn = document.getElementById("yuanEvent"); 
 //addEventListener:綁定函數(shù) 
 btn.addEventListener("click",eventOne); 
 btn.addEventListener("click",eventTwo); 
}

輸出:第一個(gè)監(jiān)聽事件 和 第二個(gè)監(jiān)聽事件

2、采用事件監(jiān)聽給對(duì)象綁定方法后,可以解除相應(yīng)的綁定,寫法如下:

var eventOne = function(){ 
 alert("第一個(gè)監(jiān)聽事件"); 
} 
function eventTwo(){ 
 alert("第二個(gè)監(jiān)聽事件"); 
} 
window.onload = function(){ 
 var btn = document.getElementById("yuanEvent"); 
 btn.addEventListener("click",eventOne); 
 btn.addEventListener("click",eventTwo); 
 btn.removeEventListener("click",eventOne); 
}

輸出:第二個(gè)監(jiān)聽事件

3、解除綁定事件的時(shí)候一定要用函數(shù)的句柄,把整個(gè)函數(shù)寫上是無法解除綁定的。

錯(cuò)誤寫法:

btn.addEventListener("click",function(){ 
 alert(11); 
}); 
btn.removeEventListener("click",function(){ 
 alert(11); 
});

正確寫法:

btn.addEventListener("click",eventTwo); 
btn.removeEventListener("click",eventOne); 

總結(jié):對(duì)函數(shù)進(jìn)行封裝后的監(jiān)聽事件如下,兼容各大主流瀏覽器。

/* 
 * addEventListener:監(jiān)聽Dom元素的事件 
 * 
 * target:監(jiān)聽對(duì)象 
 * type:監(jiān)聽函數(shù)類型,如click,mouseover 
 * func:監(jiān)聽函數(shù) 
 */ 
function addEventHandler(target,type,func){ 
 if(target.addEventListener){ 
  //監(jiān)聽IE9,谷歌和火狐 
  target.addEventListener(type, func, false); 
 }else if(target.attachEvent){ 
  target.attachEvent("on" + type, func); 
 }else{ 
  target["on" + type] = func; 
 } 
} 
/* 
 * removeEventHandler:移除Dom元素的事件 
 * 
 * target:監(jiān)聽對(duì)象 
 * type:監(jiān)聽函數(shù)類型,如click,mouseover 
 * func:監(jiān)聽函數(shù) 
 */ 
function removeEventHandler(target, type, func) { 
 if (target.removeEventListener){ 
  //監(jiān)聽IE9,谷歌和火狐 
  target.removeEventListener(type, func, false); 
 } else if (target.detachEvent){ 
  target.detachEvent("on" + type, func); 
 }else { 
  delete target["on" + type]; 
 } 
} 
var eventOne = function(){ 
 alert("第一個(gè)監(jiān)聽事件"); 
} 
function eventTwo(){ 
 alert("第二個(gè)監(jiān)聽事件"); 
} 
window.onload = function(){ 
 var bindEventBtn = document.getElementById("bindEvent"); 
 //監(jiān)聽eventOne事件 
 addEventHandler(bindEventBtn,"click",eventOne); 
 //監(jiān)聽eventTwo事件 
 addEventHandler(bindEventBtn,"click",eventTwo ); 
 //監(jiān)聽本身的事件 
 addEventHandler(bindEventBtn,"click",function(){ 
  alert("第三個(gè)監(jiān)聽事件"); 
 }); 
 //取消第一個(gè)監(jiān)聽事件 
 removeEventHandler(bindEventBtn,"click",eventOne); 
 //取消第二個(gè)監(jiān)聽事件 
 removeEventHandler(bindEventBtn,"click",eventTwo); 
} 

實(shí)例:

<!DOCTYPE html> 
<html> 
 <head> 
  <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> 
  <title>Event</title> 
  <script type="text/javascript"> 
   function addEventHandler(target,type,func){ 
    if(target.addEventListener){ 
     //監(jiān)聽IE9,谷歌和火狐 
     target.addEventListener(type, func, false); 
    }else if(target.attachEvent){ 
     target.attachEvent("on" + type, func); 
    }else{ 
     target["on" + type] = func; 
    } 
   } 
   function removeEventHandler(target, type, func) { 
    if (target.removeEventListener){ 
     //監(jiān)聽IE9,谷歌和火狐 
     target.removeEventListener(type, func, false); 
    } else if (target.detachEvent){ 
     target.detachEvent("on" + type, func); 
    }else { 
     delete target["on" + type]; 
    } 
   } 
   var eventOne = function(){ 
    alert("第一個(gè)監(jiān)聽事件"); 
   } 
   function eventTwo(){ 
    alert("第二個(gè)監(jiān)聽事件"); 
   } 
   window.onload = function(){ 
    var bindEventBtn = document.getElementById("bindEvent"); 
    //監(jiān)聽eventOne事件 
    addEventHandler(bindEventBtn,"click",eventOne); 
    //監(jiān)聽eventTwo事件 
    addEventHandler(bindEventBtn,"click",eventTwo ); 
    //監(jiān)聽本身的事件 
    addEventHandler(bindEventBtn,"click",function(){ 
     alert("第三個(gè)監(jiān)聽事件"); 
    }); 
    //取消第一個(gè)監(jiān)聽事件 
    removeEventHandler(bindEventBtn,"click",eventOne); 
    //取消第二個(gè)監(jiān)聽事件 
    removeEventHandler(bindEventBtn,"click",eventTwo); 
   } 
  </script> 
 </head> 
 <body> 
  <input type="button" value="測(cè)試" id="bindEvent"> 
  <input type="button" value="測(cè)試2" id="yuanEvent"> 
 </body> 
</html>

PS:這里再為大家提供一個(gè)關(guān)于JS事件的在線工具,歸納總結(jié)了JS常用的事件類型與相關(guān)函數(shù)功能:

javascript事件與功能說明大全:

http://tools.jb51.net/table/javascript_event

希望本文所述對(duì)大家的javascript程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • JavaScript代碼應(yīng)該放在HTML代碼哪個(gè)位置比較好?

    JavaScript代碼應(yīng)該放在HTML代碼哪個(gè)位置比較好?

    這篇文章主要介紹了JavaScript代碼應(yīng)該放在HTML代碼哪個(gè)位置比較好?本文總結(jié)了多種放置JS代碼的方法,需要的朋友可以參考下
    2014-10-10
  • 小程序安全指南之如何禁止外部直接跳轉(zhuǎn)到小程序某頁面

    小程序安全指南之如何禁止外部直接跳轉(zhuǎn)到小程序某頁面

    由于小程序跳轉(zhuǎn)的對(duì)象比較多,各自的規(guī)則又不一樣,因此小程序跳轉(zhuǎn)外部鏈接是用戶咨詢較多的問題之一,下面這篇文章主要給大家介紹了關(guān)于小程序安全指南之如何禁止外部直接跳轉(zhuǎn)到小程序某頁面的相關(guān)資料,需要的朋友可以參考下
    2022-09-09
  • 自己做的模擬模態(tài)對(duì)話框?qū)崿F(xiàn)代碼

    自己做的模擬模態(tài)對(duì)話框?qū)崿F(xiàn)代碼

    最近做完一個(gè)項(xiàng)目,發(fā)現(xiàn)瀏覽器兼容問題,模態(tài)對(duì)話框只有IE支持,但是IE9又不能支持帶框架的對(duì)話框,那個(gè)對(duì)話框的大小打死都設(shè)置不了,在網(wǎng)上查說因?yàn)楹枚喙δ鼙籌E9屏蔽了,于是自己做了一個(gè)模擬對(duì)話框的東西
    2012-05-05
  • JS函數(shù)多個(gè)參數(shù)默認(rèn)值指定方法分析

    JS函數(shù)多個(gè)參數(shù)默認(rèn)值指定方法分析

    這篇文章主要介紹了JS函數(shù)多個(gè)參數(shù)默認(rèn)值指定方法,結(jié)合實(shí)例形式分析了javascript函數(shù)參數(shù)的定義與傳遞相關(guān)操作技巧,需要的朋友可以參考下
    2016-11-11
  • javascript中方便增刪改cookie的一個(gè)類

    javascript中方便增刪改cookie的一個(gè)類

    把jquery.cookie.js改了一下,改成了純javascript版本,以備我以后項(xiàng)目只需,增加了一個(gè)得到頁面全部cookie鍵值的功能
    2012-10-10
  • Python執(zhí)行js字符串常見方法示例

    Python執(zhí)行js字符串常見方法示例

    這篇文章主要為大家介紹了Python執(zhí)行js字符串常見方法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪
    2022-04-04
  • js實(shí)現(xiàn)選項(xiàng)卡效果

    js實(shí)現(xiàn)選項(xiàng)卡效果

    這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)選項(xiàng)卡效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-03-03
  • DOM節(jié)點(diǎn)刪除函數(shù)removeChild()用法實(shí)例

    DOM節(jié)點(diǎn)刪除函數(shù)removeChild()用法實(shí)例

    這篇文章主要介紹了DOM節(jié)點(diǎn)刪除函數(shù)removeChild()用法,實(shí)例分析了removeChild()函數(shù)實(shí)現(xiàn)結(jié)點(diǎn)刪除的技巧,需要的朋友可以參考下
    2015-01-01
  • ES6的新特性概覽

    ES6的新特性概覽

    Nick Justice是GitHub開發(fā)者計(jì)劃的一員。早在ES6語言標(biāo)準(zhǔn)發(fā)布之前,他就借助像Babel這樣的轉(zhuǎn)譯器以及最新版本的瀏覽器在自己的項(xiàng)目中使用ES6特性。他認(rèn)為,ES6的新特性將極大地改變JavaScript的編寫方式
    2016-03-03
  • JavaSript中變量的作用域閉包的深入理解

    JavaSript中變量的作用域閉包的深入理解

    js中的變量都是公用的沒有靜態(tài)變量,下面為大家介紹下變量的作用域閉包,需要的朋友可以參考下
    2014-05-05

最新評(píng)論