javascript - addEventListener 为什么事件默认就执行了?

查看:243
本文介绍了javascript - addEventListener 为什么事件默认就执行了?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

问 题

以下代码,给class="inner"元素添加点击事件,但是打开浏览器事件就被执行了,并且传入的事件对象是undefined

<body>
<div class="outer">
    o
    <div class="inner">i</div>
</div>
<script type="text/javascript" src='./util/util.js'></script>
<script type="text/javascript">
    var dOuter=document.querySelector('.outer');
    var dInner=document.querySelector('.inner');
    dInner.addEventListener('click',conInfo(event),false);
    dOuter.addEventListener('click',conInfo(event),false);
    function conInfo(event){
        console.log('event...');
        console.log(event);
    }
</script>
</body>

打开浏览器 事件就执行了,并且传入的event=undefined

解决方案

去掉里面的参数,不能这么写。

conInfo 是一个函数, 你在它后面加上 (event), 相当于执行了

函数,而event是未定义的参数,所以会显示函数已执行,并打印出

undefined.

这篇关于javascript - addEventListener 为什么事件默认就执行了?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆