首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >window.removeEventListener未从窗口中删除事件

window.removeEventListener未从窗口中删除事件
EN

Stack Overflow用户
提问于 2020-01-21 23:55:52
回答 2查看 46关注 0票数 0

大家好,我只是试图从窗口中删除此keyup事件,但它不起作用。

代码语言:javascript
复制
  toggle(forceClose = false) {
    const shouldClose = forceClose || this.isOpen()
    const action = shouldClose ? 'remove' : 'add'
    const expanded = !shouldClose

    var escape = function(e) {
      if (e.key === "Escape" || e.which === 27) {
        console.log("Escape")
      }
    }

    if (shouldClose && this.targetEl) {
      window.removeEventListener('keyup', escape, true)
      this.targetEl.classList.remove(this.options.menuActiveClass)
      setTimeout(() => !this.targetEl.classList.contains(this.options.menuActiveClass) && this.targetEl.classList.remove(this.options.menuOpenClass), 300)
    } else if (this.targetEl) {
      window.addEventListener('keyup', escape, true)
      this.targetEl.classList.add(this.options.menuOpenClass)
      setTimeout(() => this.targetEl.classList.contains(this.options.menuOpenClass) && this.targetEl.classList.add(this.options.menuActiveClass), 10)
    }

  }
EN

回答 2

Stack Overflow用户

发布于 2020-01-21 23:58:48

您将在每次调用时创建一个新的escape函数。因此,removeEventListener将尝试删除一些从未添加的内容。

将声明移动到外部范围

代码语言:javascript
复制
  toggle(forceClose = false) {
    const shouldClose = forceClose || this.isOpen()
    const action = shouldClose ? 'remove' : 'add'
    const expanded = !shouldClose



    if (shouldClose && this.targetEl) {
      window.removeEventListener('keyup', escape, true)
      this.targetEl.classList.remove(this.options.menuActiveClass)
      setTimeout(() => !this.targetEl.classList.contains(this.options.menuActiveClass) && this.targetEl.classList.remove(this.options.menuOpenClass), 300)
    } else if (this.targetEl) {
      window.addEventListener('keyup', escape, true)
      this.targetEl.classList.add(this.options.menuOpenClass)
      setTimeout(() => this.targetEl.classList.contains(this.options.menuOpenClass) && this.targetEl.classList.add(this.options.menuActiveClass), 10)
    }

  }

function escape(e) {
  if (e.key === "Escape" || e.which === 27) {
    console.log("Escape")
  }
}
票数 1
EN

Stack Overflow用户

发布于 2020-01-21 23:59:07

当你调用removeEventListener时,你必须在addEventListener上传递相同的实例作为函数。

因此在本例中,您必须定义换码ouside切换

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59844797

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档