javascript - 如何实现只触发一次的 listener,类似 jQuery.one()
伊谢尔伦
伊谢尔伦 2017-04-11 12:08:32
[JavaScript讨论组]

试了两种方法,都不行,求大神指教


// 方法一
let listenOnce = (node, type, listener, useCapture=false) => {
    let wrapper = (event) => {
        console.log('wrapper called')
        node.removeEventListener(type, wrapper, useCapture);
        console.log('removed')
        return listener(event);
    }

    node.addEventListener(type, wrapper, useCapture);
}

listenOnce(document, 'click', foobar);

// 方法二
let listenerWithTimes = (times, listener) => {
    let count = times;
    return (event) => {    
        if (count > 0) {
            console.log(count);
            listener(event);
        }
        count -= 1;
    }
}

document.addEventListener('click', listenerWithTimes(1, foobar));
伊谢尔伦
伊谢尔伦

小伙看你根骨奇佳,潜力无限,来学PHP伐。

全部回复(1)
黄舟

你确定不行吗?我想应该是其它错误了。请用chrome测试下面代码,我这里完全正确:

<script>
let listenOnce = (node, type, listener, useCapture=false) => {
    let wrapper = (event) => {
        console.log('wrapper called')
        node.removeEventListener(type, wrapper, useCapture);
        console.log('removed')
        return listener(event);
    }

    node.addEventListener(type, wrapper, useCapture);
}

listenOnce(document, 'click', function(){
    console.log('listener');
});
</script>
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号