javascript如何刪除所有事件監(jiān)聽器
javascript 刪除所有事件監(jiān)聽器
移除 JavaScript 中的所有事件監(jiān)聽器
EventTarget 接口的 addEventListener()
方法配置一個(gè)函數(shù),只要指定的事件被傳遞到目標(biāo),就會(huì)調(diào)用該函數(shù)。
addEventListener()
方法的工作原理是將實(shí)現(xiàn) EventListener 的函數(shù)或?qū)ο筇砑拥绞录陕犉髁斜碇?,以用于在調(diào)用它的 EventTarget 中指定的事件類型。
如果該函數(shù)或?qū)ο笠言谠撃繕?biāo)的事件偵聽器列表中,則不會(huì)再次添加該函數(shù)或?qū)ο蟆?/p>
EventTarget 接口的 removeEventListener()
方法刪除了之前使用 EventTarget.addEventListener()
從目標(biāo)注冊(cè)的事件監(jiān)聽器。
使用未標(biāo)識(shí)當(dāng)前在 EventTarget 中注冊(cè)的 EventListener 的參數(shù)調(diào)用 removeEventListener()
無效。
如果在目標(biāo)上的另一個(gè)偵聽器正在處理事件時(shí)從 EventTarget 中刪除 EventListener,則不會(huì)調(diào)度該事件。 但是,它可以重新定位。
如果只為特定元素注冊(cè)了一個(gè)或兩個(gè)偵聽器,則調(diào)用 removeEventListener 很容易。 如果注冊(cè)的偵聽器超過 10 個(gè),而您想刪除所有事件偵聽器怎么辦?
這需要努力; 我們將學(xué)習(xí)另一種方法來執(zhí)行這個(gè)繁瑣的操作來克服這個(gè)問題。
讓我們看看下面的例子。
<div> <button id="grt-btn">Hello World!</button> <button onclick="removeListeners()">Remove listeners</button> </div>
document.getElementById("grt-btn").addEventListener("click", () => { console.log("firstClick") }, false); document.getElementById("grt-btn").addEventListener("blur" , () => { console.log("Blur event") }, false); document.getElementById("grt-btn").addEventListener("focus", () => { console.log("focus event") }, false); function removeListeners() { const oldBtnElement = document.getElementById("grt-btn"); const newBtnElement = oldBtnElement.cloneNode(true); oldBtnElement.parentNode.replaceChild(newBtnElement, oldBtnElement); console.log("Removed all listners") }
在上面的例子中,我們定義了 2 個(gè)按鈕。 第一個(gè)按鈕是將聽眾附加到它的按鈕。
第二個(gè)按鈕將移除第一個(gè)按鈕的偵聽器。
我們定義了三個(gè)事件監(jiān)聽器; 只要點(diǎn)擊 Hello World 按鈕,就會(huì)觸發(fā)焦點(diǎn)和點(diǎn)擊事件。 嘗試導(dǎo)航到另一個(gè)選項(xiàng)卡; 它會(huì)觸發(fā)模糊事件。
最后,單擊 Remove listeners 按鈕,這將克隆 Hello World 按鈕。 最后一步是將 div 元素的子節(jié)點(diǎn)替換為 cloneNode。
這將自動(dòng)刪除之前與該按鈕關(guān)聯(lián)的所有事件偵聽器。
如果您嘗試再次單擊 Hello World 按鈕,它不會(huì)觸發(fā)任何事件。
輸出:
"focus event"
"firstClick"
"Blur event"
"focus event"
"Blur event"
"Removed all listeners"
javaScript刪除對(duì)象屬性總結(jié)方法
一、刪除js中對(duì)象中屬性
1.使用delete運(yùn)算符
例:
1) 使用點(diǎn)屬性訪問器刪除:
delete object.property;
在屬性訪問器上應(yīng)用delete
運(yùn)算符時(shí),運(yùn)算符會(huì)從對(duì)象中刪除相應(yīng)的屬性:
const obj = {name: '腳本之家',url: 'rwlok.com'}; delete obj.url; console.log(obj); // { name: '腳本之家' }
2) 使用方括號(hào)屬性訪問器刪除:
delete object['property'];// orconst name = 'dynamicProperty'; delete object[name];
使用delete
運(yùn)算符刪除屬性是可變的,因?yàn)樗鼤?huì)改變?cè)紝?duì)象。
如果要?jiǎng)h除的屬性名稱是動(dòng)態(tài)確定的,則可以使用方括號(hào)語(yǔ)法:
const obj = { name: '腳本之家', url: 'rwlok.com'}; const name = 'url'; delete obj[name]; console.log(obj); // { name: '腳本之家' }
2.使用rest解構(gòu)對(duì)象
1) 屬性名稱已知:
const { property, ...restObject } = object;
應(yīng)用解構(gòu)和rest
語(yǔ)法后,restObject
將包含與object
相同的屬性,只是沒有刪除的屬性。
const obj= { name: '腳本之家', url: 'rwlok.com' }; const { url, ...objRest } = obj; console.log(objRest); // { name: '腳本之家' } console.log(obj); // { name: '腳本之家',url: 'rwlok.com' }
2) 屬性名稱是動(dòng)態(tài)的:
const name = 'property'; const { [name]: removedProperty, ...restObject } = object;
如果要?jiǎng)h除的屬性名稱是動(dòng)態(tài)確定的,則可以使用動(dòng)態(tài)屬性名稱解構(gòu)語(yǔ)法:
const obj = { name: '腳本之家', url: 'rwlok.com'}; const name = 'url'; const { [name]: removedProperty, ...objRest } = obj; console.log(objRest); // { name: '腳本之家' }
rest結(jié)構(gòu)方法還可以一次性刪除多個(gè)屬性:
const obj = { name: '腳本之家', url: 'rwlok.com', title: '卡卡測(cè)速網(wǎng)', }; const { url, title, ...objRest } = obj; console.log(objRest); // { name: '腳本之家' }
到此這篇關(guān)于javascript 刪除所有事件監(jiān)聽器的文章就介紹到這了,更多相關(guān)js刪除事件監(jiān)聽器內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- JavaScript鼠標(biāo)拖動(dòng)事件監(jiān)聽使用方法以及實(shí)例效果演示
- 關(guān)于js中removeEventListener取消事件監(jiān)聽的坑
- vue.js綁定事件監(jiān)聽器示例【基于v-on事件綁定】
- vue.js過濾器+ajax實(shí)現(xiàn)事件監(jiān)聽及后臺(tái)php數(shù)據(jù)交互實(shí)例
- vuejs2.0實(shí)現(xiàn)分頁(yè)組件使用$emit進(jìn)行事件監(jiān)聽數(shù)據(jù)傳遞的方法
- javascript 組合按鍵事件監(jiān)聽實(shí)現(xiàn)代碼
- 一文詳解JavaScript的事件監(jiān)聽(最新整理)
相關(guān)文章
uniapp實(shí)現(xiàn)微信小程序的電子簽名效果(附demo)
本文主要介紹了uniapp實(shí)現(xiàn)微信小程序的電子簽名效果,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-05-05JavaScript一元正號(hào)運(yùn)算符示例代碼
這篇文章主要給大家介紹了關(guān)于JavaScript一元正號(hào)運(yùn)算符的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用JavaScript具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-06-06JS實(shí)現(xiàn)在Repeater控件中創(chuàng)建可隱藏區(qū)域的代碼
在WEB應(yīng)用中,如何才能使應(yīng)用高效率呢?如何才能吸引用戶呢?這的確是個(gè)大學(xué)問,頁(yè)面的內(nèi)容,色搭配等都十分重要。但不可忽視的是,多數(shù)情況下,對(duì)于數(shù)據(jù)的呈現(xiàn)方式也是十分重要的。2010-09-09重寫JS setTimeout 方法 JavaScript Hook
想要重寫 setTimeout 方法,發(fā)現(xiàn)有動(dòng)態(tài)引入的js,需要改成自己的js,以下教教大家這個(gè)需求,防止網(wǎng)站被劫持2023-07-07Layui Table js 模擬選中checkbox的例子
今天小編就為大家分享一篇Layui Table js 模擬選中checkbox的例子,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-09-09javascript的列表切換【實(shí)現(xiàn)代碼】
下面小編就為大家?guī)硪黄猨avascript的列表切換【實(shí)現(xiàn)代碼】。小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。2016-05-05