javascript - btn.addEventListener('click',fn,false);怎么给fn传参数?
我想大声告诉你
我想大声告诉你 2017-05-18 10:50:06
[JavaScript讨论组]

试过了貌似传不进去???

我想大声告诉你
我想大声告诉你

全部回复(6)
習慣沉默

为什么这么多人踩?我觉得是个好问题啊,闭包解决之

<button>click</button>
<script>
    document.querySelector("button").addEventListener("click", fn('hello world'), false);
    
    function fn(a) {
        return function() {
            alert(a);
        }
    }
</script>
黄舟

不知道你想传什么。

不过你可以把fn定义成返回函数的函数。基本能满足需求……

给我你的怀抱
btn.addEventListener('click',function(){fn('params')});
function fn(data) {
    alert(data)
}

这样试试?

巴扎黑
document.getElementById('aaa').addEventListener('click', fn('asdadad'), false);

function fn(data) {
    console.info(data);
}
巴扎黑
function foo(a, b, c) {}

// 不要这样做
setTimeout('foo(1,2, 3)', 1000)

// 可以使用匿名函数完成相同功能
setTimeout(function() {
    foo(1, 2, 3);
}, 1000)
巴扎黑

我没找到addEventListener的函数原型,在平时使用中我的感觉是。
addEventListener在捕捉到触发事件之后,给调用函数名后加()调用
那么

btn.addEventListener('click',fn,false);

的监听事件addEventListener捕捉到click事件之后,执行的函数便是 fn()
addEventListener有的这个弊端就是它不能添加带参数的括号,即不能捕捉到click之后执行 fn(1,2).
所以平时的时候,我都是使用一个匿名函数function(){fn(1,2)}作为绑定函数。那么代码变成了这样:

btn.addEventListener('click',function(){fn(1,2)},false)

在捕捉到click事件之后,触发的函数便是
function(){fn(1,2)}()
即可实现触发fn(1,2)这样的带参数函数。

对addEventListener函数还不是很熟,欢迎讨论指正。

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

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