一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服務器之家 - 編程語言 - JavaScript - addEventListener()和removeEventListener()追加事件和刪除追加事件

addEventListener()和removeEventListener()追加事件和刪除追加事件

2021-12-03 16:55Sarah119 JavaScript

這篇文章主要給大家介紹了關于addEventListener()和removeEventListener()追加事件和刪除追加事件的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學

addEventListener()與removeEventListener()用于追加事件和刪除追加。所有的DOM節點中都包含這兩種方法,并且它們都接受3個參數:要處理的事件名、作為事件處理程序的函數和一個布爾值。

最后這個布爾值參數是true,表示在捕獲階段調用事件處理程序;如果是false,表示在冒泡階段調用事件處理程序。默認為false;

要在按鈕上為click事件添加事件處理程序,可以使用下列代碼:

?
1
2
3
4
1 var btn = document.getElementById("myBtn");
2 btn.addEventListener("click", function () {
3  alert(this.id);
4 }, false);

使用DOM2級方法添加事件處理程序的主要好處是可以添加多個事件處理程序。來看下面的例子:

?
1
2
3
4
5
6
7
var btn = document.getElementById("myBtn");
btn.addEventListener("click", function () {
 alert(this.id);
}, false);
btn.addEventListener("click", function () {
 alert("Hello World");
}, false);

通過addEventListener()添加的事件處理程序只能使用removeEventListener()來移除;移除時傳入的參數與添加處理程序時使用的參數相同。這也意味著通過addEventListener()添加的匿名函數無法移除,如下面的例子所示:

?
1
2
3
4
5
6
7
var btn = document.getElementById("myBtn");
btn.addEventListener("click", function () {
 alert(this.id);
}, false);
btn.removeEventListener("click", function () { //無效!
 alert(this.id);
}, false);

在這個例子中,removeEventListener無法刪除addEventListener所追加的事件,因為兩個方法并不相等,內存地址已經是不同的,如下面的例子所示:

?
1
2
3
4
5
6
var btn = document.getElementById("myBtn");
var handler = function () {
  alert(this.id);
 };
btn.addEventListener("click", handler, false);
btn.removeEventListener("click", handler, false); //有效!

重寫后的這個例子沒有問題,是因為在addEventListener()和removeEventListener()中用來相同的函數。

大多數情況下,都是將事件處理程序添加到事件流的冒泡階段,這樣可以最大限度地兼容各種瀏覽器。最好只在需要在是時間到達目標之前截獲它的時候將事件處理程序添加到捕獲階段。如果不是特別需要,我們不建議在事件捕獲階段注冊事件處理程序;

親測:

方法的內存地址十分的重要,一定要相同才可以刪除;試過遇到的坑:

?
1
2
3
4
5
6
7
8
9
10
11
var clickFun = null;
aa = function(){
 clickFun = function(){
  alert("1")
 }
 window.removeEventListener("click",clickFun,false)
 window.addEventListener("click",clickFun,false)
}
setInterval(function(){
 aa()
},2000)

需求,需要不斷地往一個function里面塞數據,里面會有追加,如果不刪除了話,會一直追加上去,不環保并且耗內存,必須要刪掉追加;然而像上面這樣寫的話,由于removeEventListener和addEventListener里面的clickFun內存不相等,導致刪除不成功;調整如下:

?
1
2
3
4
5
6
7
8
9
10
11
var clickFun = null;
aa = function(){
 !clickFun && (window.removeEventListener("click",clickFun,false));
 clickFun = function(){
  alert("1")
 }
 window.addEventListener("click",clickFun,false)
}
setInterval(function(){
 aa()
},2000)

確保刪除的是同一個內存的方法

到此這篇關于addEventListener()和removeEventListener()追加事件和刪除追加事件的文章就介紹到這了,更多相關addEventListener()和removeEventListener()追加事件內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://www.cnblogs.com/Sarah119/p/7825265.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 欧美人曾交 | 日韩大片在线播放 | 成人亚洲欧美日韩在线观看 | 嫩草影院永久入口在线观看 | 日韩一区二三区无 | 秋葵视频成人 | 欧美成人aletta ocean | 欧美一卡二卡科技有限公司 | 久久精品一区二区免费看 | 久久天天躁狠狠躁夜夜躁 | 国产麻豆精品入口在线观看 | 国产日韩欧美综合一区二区三区 | 小小水蜜桃视频高清在线播放 | 色噜噜狠狠色综合 | 日本在线视频免费观看 | 欧洲男同直粗无套播放视频 | 国内精品 大秀视频 日韩精品 | 玩逼逼| 国产欧美va欧美va香蕉在线观 | 乖女的嫩奶水h文孕妇 | 亚洲高清中文字幕一区二区三区 | 女人被男人躁得好爽免费视频 | 五月色天在线视频综合观看 | 91精品国产综合久 | 国产亚洲精品激情一区二区三区 | 午夜影院小视频 | 亚洲国产综合久久久无码色伦 | 特级毛片免费视频观看 | 欧美日韩视频在线第一区二区三区 | 国产亚洲成归v人片在线观看 | japanese乱子mate | 亚洲国产AV一区二区三区四区 | 男女拍拍拍免费视频网站 | 图片专区亚洲欧美另类 | 欧美高清免费一级在线 | 亚洲国产情侣偷自在线二页 | 久久精品无码人妻无码AV蜜臀 | 456亚洲人成高清在线 | 猫咪av | 国产精品对白刺激久久久 | 91精品国产高清久久久久久 |