javascript - * 选择器上绑定(bind)单击事件时多次执行

标签 javascript jquery google-chrome google-chrome-extension

我正在构建一个 Chrome 扩展。在与网页交互的 content.js 中,我将点击事件绑定(bind)到所有元素。

Google 官方文档称,content.js 中的任何内容都将像网页或应用程序中的普通 js 文件一样执行。由于我对jQuery不熟悉,也许将事件绑定(bind)到所有元素时应该会出现问题。这是我使用的代码。

$(function () {

    $('*').on('click',function (event) {

    console.log("clicked");

    });
});

任何帮助将不胜感激:)

最佳答案

您可能不应该将点击事件绑定(bind)到页面上的每个元素,这是非常糟糕的做法。

相反,通过事件委托(delegate),您可以将点击处理程序附加到主体,以对所有元素进行操作;

$('body').on('click', '*', function (e) {
  e.stopPropagation();
  // do some stuff
});

将其与e.stopPropagation()结合使用将确保点击事件仅被触发一次。您可以使用 e.currentTarget 访问实际单击的元素。

关于javascript - * 选择器上绑定(bind)单击事件时多次执行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34088030/

相关文章:

javascript - 使用 Angular 有条件地隐藏 Bootstrap 工具提示内的文本内容

javascript - 沿着另一个对象移动一个对象,在 tween.js 中创建动画

javascript - `fail` 类添加到 jQuery 中的 MixItUp 容器

javascript - 防止 Firefox 中的默认 Tab 键行为

javascript - GOJS 将 Canvas 图导出为图像

JQuery 验证组成功消息

javascript 将字符串作为函数调用

c# - Process.Start() 在 Windows 10/Chrome 上去掉井号和之后的所有内容

css - 下拉菜单在 chrome 中不起作用

CSS3 选取框在 Chrome 和 Opera 中不滑动