首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >混淆addEventListener

混淆addEventListener
EN

Stack Overflow用户
提问于 2021-03-01 15:56:00
回答 1查看 30关注 0票数 0

我编写了一个去反跳函数,并希望使用该函数显示输入。

代码语言:javascript
复制
    let btn = document.querySelector('.firstScreen')
    let input = document.querySelector('input')

    function debounce(fn, time) {
        let timer = null
        return function(...args){
            if (timer) clearTimeout(timer)
            timer = setTimeout(() => {
                fn()
            }, time)
        }
    }

    function display(){
        btn.children[1].innerHTML=input.value
    }

当我这样写的时候,它不工作:

代码语言:javascript
复制
  document.addEventListener('keyup',function(){
        debounce(display, 2000)
    })

但是像这样工作:

代码语言:javascript
复制
    document.addEventListener('keyup',debounce(display, 2000))

为什么?

EN

回答 1

Stack Overflow用户

发布于 2021-03-01 16:02:50

您可以根据需要从debounce(display, 2000)返回函数。该函数不能作为函数调用,因此第一个示例不使用返回的函数,而只是创建您应该使用的函数

你可以这样做

代码语言:javascript
复制
document.addEventListener('keyup',function(){ return debounce(display, 2000) }) 

当你可以做你已经确定的工作时,这是对代码的浪费。

代码语言:javascript
复制
document.addEventListener('keyup',debounce(display, 2000))
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/66418418

复制
相关文章

相似问题

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