javascript - 關於js原生事件的綁定與解除綁定
巴扎黑
巴扎黑 2017-07-05 10:38:23
0
2
628

直接上程式碼

ele.addEventListener('click', function(e) {
    console.log(e)
})

這裡我需要在一定的情況下對ele的click事件進行解除綁定的操作,但是在綁定的時候我需要使用額外的參數比如event,我該怎麼解除綁定呢?

我知道removeEventListener可以解綁,但是他們要傳入的那個函數必須是一個相同的具名外部函數,在我需要參數的情況下行不通了

我也知道在只需要綁定一個click事件的時候用ele.click = function() {}然後再用ele.click = null來解綁,或者使用其他工具庫提供的方法.

但是現在我只要知道就用removeEventListener來解除有沒有可能

謝謝

巴扎黑
巴扎黑

全部回覆(2)
淡淡烟草味

這樣就行,綁定和解綁的函數只要是指向同一個就ok

function handler(e){
    //操作
    console.log(e)
}
ele.addEventListener('click', handler);//绑定
ele.removeEventListener('click', handler);//解绑
小葫芦
function bindFunc(e) {
    console.log(e);
    //用参数e来进行一些操作,干啥都行
}
this.cusBindFunc = bindFunc.bind(this, e); //bind一下,因为remove的时候用的func必须和绑定的时候一样
ele.addEventListener('click', this.cusBindFunc);//绑定事件
ele.removeEventListener('click', this.cusBindFunc);//解绑

另外為了相容性,可以相容於attachEvent, detachEvent

不知道我是否理解了你的問題@AugustEchoStone

熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!