首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何将事件绑定到元素和所有子元素,但只触发一次?

如何将事件绑定到元素和所有子元素,但只触发一次?
EN

Stack Overflow用户
提问于 2015-02-20 14:29:05
回答 2查看 254关注 0票数 0

这就是HTML的样子:

代码语言:javascript
复制
<a href="#" id="back-button" data-transition="slide" data-direction="reverse" data-role="button">
  <div class="nav-item-desc">Back</div>
</a>

下面是如何绑定单击事件:

代码语言:javascript
复制
$("#back-button").contents().addBack().off().on("click", function(e)
{
});

现在,当我单击div (在文本上)时,事件会被触发一次,当我单击链接(按钮上的文本旁边)时,它会被触发两次。

我该怎么解决这个问题?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-02-20 14:33:39

您的代码应该是:

代码语言:javascript
复制
$("#back-button").on("click", function(e){
    // e.target is the specific clicked element
});
票数 1
EN

Stack Overflow用户

发布于 2015-02-20 14:33:04

看看http://api.jquery.com/one/

代码语言:javascript
复制
$("#back-button").contents().addBack().off().one("click", function(e){});
票数 -2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/28631325

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档