JavaScript注冊監(jiān)聽事件和清除監(jiān)聽事件方式詳解
前言
JavaScript中有兩種方法可以注冊監(jiān)聽事件,一種是傳統(tǒng)的注冊方式,on+事件名稱的注冊方法,如btn.onclick,還有方法監(jiān)聽事件注冊方式, addEventListener()和ie8以下的attachEvent()。
注冊監(jiān)聽事件
傳統(tǒng)方式
語法格式:元素名.on+事件名稱 = function () {函數(shù)代碼}
這種方法只能為元素注冊一個事件,如果注冊多個,那么就會覆蓋。
這種方式比較簡單,看一個案例
點擊事件案例:判斷閏年
我們寫一個輸入框和按鈕,給按鈕注冊點擊事件,在按鈕點擊的時候,判斷輸入框里面輸入的值是否是閏年。
<input type="text" id="inp" /> <button id="nian">輸入年份后點擊判斷</button>
var nian = document.getElementById("nian"); var inp = document.getElementById("inp"); nian.onclick = function () { var a = inp.value; if (a == null || a == 0) { alert("沒有輸入年份!"); } else if (a <= 0) { alert("輸入年份有錯誤!"); } else if (a % 400 == 0 || (a % 4 == 0 && a % 100 != 0)) { alert("輸入年份為閏年!"); } else { alert("輸入年份不是閏年!"); } };
方法監(jiān)聽事件注冊方式
addEventListener()
我們使用addEventListener()來注冊監(jiān)聽。它可以為一個事件源注冊多個事件。
語法:
btn.addEventListener('click', function () {函數(shù)代碼塊}, false)
- 第一個參數(shù):事件類型,如click
- 第二個參數(shù):回調(diào)函數(shù),事件發(fā)生后要運行的內(nèi)容
- 第三個參數(shù):布爾值,默認是false,決定是否支持冒泡
注意,在在標(biāo)準(zhǔn)瀏覽器瀏覽器下,addEventListener()是可用的。但是在ie8之下addEventListener()無法使用。這時候我們使用attachEvent()來注冊監(jiān)聽事件。
attachEvent()
語法:
btn.attachEvent('onclick',function(){函數(shù)代碼塊},false)
參數(shù)是基本相同,注意attachEvent()的第一個參數(shù),需要在事件前面加'on'。
addEventListener()與attachEvent()的兼容
在不同瀏覽器下,存在注冊監(jiān)聽事件的兼容問題,我們可以寫一個函數(shù)來解決這個問題,把函數(shù)封裝起來方便隨時調(diào)用,這樣也可以加深兩個方法的理解。
代碼如下,我們給按鈕注冊點擊事件。 注釋有詳解。
var btn = document.getElementById('btn')//獲取按鈕 function clicks(controls, events, buer) {//三個形參 if (controls.addEventListener) {//判斷addEventListener是否可以使用 controls.addEventListener(events, function () {//添加監(jiān)聽事件 console.log('標(biāo)準(zhǔn)瀏覽器');//打印輸出 }, buer) } else {//判斷不兼容addEventListener,所以使用attachEvent controls.attachEvent('on' + events, function () {//注意不要忘了這個on console.log('非標(biāo)準(zhǔn)瀏覽器'); }, buer) } } clicks(btn, 'click', false)//調(diào)用與傳參
移除監(jiān)聽事件
傳統(tǒng)方法的移除
我們在使用 元素名.on+事件名稱 = function () {函數(shù)代碼}的方式注冊監(jiān)聽事件的時候,只需要使用
元素名.on+事件名稱 =null,就可以移除監(jiān)聽事件。
移除方法監(jiān)聽事件注冊方式
removeEventListener()
語法:元素名.removeEventListener('事件名稱',函數(shù))
內(nèi)容分別是:移除哪個元素(事件源/元素名),通過什么方式觸發(fā)(事件類型)的什么事件(事件回調(diào))
removeEventListener()是常用的移除監(jiān)聽事件的方法。但在ie8以下,它是不可以使用的。所以我們使用detachEvent()來為ie8之下的瀏覽器清除監(jiān)聽事件。
btn.detachEvent()
元素名.detachEvent('on+事件名稱, 函數(shù))
基本與removeEventListener()相同,但注意事件名稱前面加'on'
removeEventListener()與btn.detachEvent()的兼容
我們可以效仿addEventListener()與attachEvent()的兼容解決辦法寫一個函數(shù)。
如下:
function getEvent(element, eventName, callback) { if (element.removeEventListener) { //標(biāo)準(zhǔn)瀏覽器的注冊監(jiān)聽 element.removeEventListener(eventName, callback) } else { //非標(biāo)準(zhǔn)瀏覽器的注冊監(jiān)聽 element.detachEvent('on' + eventName, callback) } } getEvent(btn,'click',fun)
案例:注冊監(jiān)聽與移除事件的結(jié)合
我們寫一個案例,來實現(xiàn)注冊監(jiān)聽,和移除事件。
首先寫兩個案例,第一個按鈕注冊監(jiān)聽事件,如點擊事件,點擊一下就打印一串文字。為第二個按鈕注冊點擊事件,第二個按鈕點擊后移除事件,使得第一個按鈕點擊后無法打印文字。
也要注意注冊監(jiān)聽和移除事件的兼容,一并寫入代碼中。
代碼如下:
var btn = document.getElementById('btn') var btn1 = document.getElementById('btn1') function fun() {//函數(shù):打印一串文字 console.log('標(biāo)準(zhǔn)瀏覽器'); } function fn() {//函數(shù):打印一串文字 console.log('非標(biāo)準(zhǔn)瀏覽器'); } function clicks(controls, events, buer) {//為按鈕1注冊點擊事件的兼容 if (controls.addEventListener) { controls.addEventListener(events, fun, buer)//調(diào)用之前的打印函數(shù) console.log('添加了點擊事件'); } else { controls.attachEvent('on' + events, fn, buer) console.log('添加了點擊事件'); } } clicks(btn, 'click', false)//函數(shù)調(diào)用 btn1.onclick = function () {//為按鈕2注冊監(jiān)聽事件 function rem(controls,events, functionname) {//為按鈕2注冊移除事件的兼容 if (controls.removeEventListener) { controls.removeEventListener(events, functionname) } else { controls.detachEvent('on' + events, functionname) } } rem(btn, 'click', fun)//函數(shù)調(diào)用 console.log('現(xiàn)在清除了按鈕1的點擊事件'); }
總結(jié)
到此這篇關(guān)于JavaScript注冊監(jiān)聽事件和清除監(jiān)聽事件的文章就介紹到這了,更多相關(guān)js注冊監(jiān)聽事件和清除內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JS實現(xiàn)點擊發(fā)送驗證碼 xx秒后重新發(fā)送功能
在一些注冊類的網(wǎng)站,經(jīng)常遇到這樣的需求,點擊發(fā)送驗證碼,xx秒后重新發(fā)送,這樣的功能怎么實現(xiàn)呢,接下來通過本文給大家分享js點擊發(fā)送驗證碼 xx秒后重新發(fā)送功能,需要的朋友參考下吧2019-07-07JavaScript Array對象擴展indexOf()方法
JavaScript中Array對象沒有indexOf()方法,可通過下面的代碼擴展,需要的朋友可以參考下2014-05-05javascript利用apply和arguments復(fù)用方法
這篇文章主要介紹了javascript利用apply和arguments復(fù)用方法,有需要的朋友可以參考一下2013-11-11JavaScript判斷表單提交時哪個radio按鈕被選中的方法
這篇文章主要介紹了JavaScript判斷表單提交時哪個radio按鈕被選中的方法,實例分析了javascript操作表單radio按鈕的技巧,非常具有實用價值,需要的朋友可以參考下2015-03-03layUI使用layer.open,在content打開數(shù)據(jù)表格,獲取值并返回的方法
今天小編就為大家分享一篇layUI使用layer.open,在content打開數(shù)據(jù)表格,獲取值并返回的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-09-09