Chrome 扩展程序:事件侦听器
Chrome Extension: event listeners
我知道由于Chrome的csp,我无法执行内联JavaScript。我有一个名为popup的html文件.html其中包含以下内容:
<body>
<a href="#" id="clickme">Button</a>
</body>
以及一个名为chrome的外部JavaScript文件.js其中包含以下代码:
document.addEventListener('DOMContentLoaded', init());
function init(){
var elem = document.getElementById('clickme');
elem.addEventListener('click',func());
}
function func(){
alert('button clicked');
}
每当我重新加载Chrome扩展程序或单击扩展程序图标时,func()
都会被触发,但是当我单击侦听器订阅的实际按钮(按钮)时,没有任何反应。我已经使用"检查弹出窗口"并在控制台中使用location.reload()
查看了调试器,似乎通过 getElementById()
正确设置了 elem ,但事件在重新加载页面时立即触发,而不是在单击链接时。
如何让事件在点击时触发,而不是在页面加载时触发?
将
函数传递给事件侦听器,如下所示document.addEventListener('DOMContentLoaded', init());
立即调用该函数。正确的方法是这样做
document.addEventListener('DOMContentLoaded', init);
相关文章:
- 如何在for循环中添加事件侦听器
- 未命中服务器发送的事件侦听器
- 如何覆盖原型中的事件侦听器
- 无法将事件侦听器附加到画布
- 如何在d3.js中自定义事件侦听器
- 在es6中,将带有回调的事件侦听器设置为可迭代的
- 事件侦听器未在chrome扩展中的options.js中启动
- IE8更改文本区域上的事件侦听器不工作
- 将事件侦听器添加到文档,而不是签入元素存在,然后添加事件侦听器
- javascript删除事件侦听器
- 我应该/如何清除mousemove JQuery事件侦听器
- 在JQuery中使用谷歌地图Api事件/侦听器
- 如何使用我的Jquery代码创建委托事件侦听器
- 'mousemove'画布中的事件侦听器-指针仅在最后一个矩形中更改
- 为什么此事件侦听器不工作
- 是否可以在数字输入框中的小按钮中添加事件侦听器
- 在Google Chrome扩展中添加事件侦听器
- SVG元素在转换后会丢失事件侦听器
- jQuery事件侦听器多次启动
- 如何在不删除类似侦听器的情况下从父对象中删除jQuery事件侦听器