微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

为什么我的jQuery点击处理程序似乎对其某些目标运行多次?

我申请:
$(".newContentLink").click(function() {
    $("#test").append("1");
});

在此:

<span id="contents">
<input class="newContentLink" type="submit" style="width: 100%;" value="CREATE A NEW CONTENT"/>
<span id="content1" class="content study">
</span>
<input class="newContentLink" type="submit" style="width: 100%;" value="CREATE A NEW CONTENT"/>
<span id="content3" class="content study">
</span>
<input class="newContentLink" type="submit" style="width: 100%;" value="CREATE A NEW CONTENT"/>
<span id="content4" class="content category">
</span>
<input class="newContentLink" type="submit" style="width: 100%;" value="CREATE A NEW CONTENT"/>
</span>

怎么来的
当我点击前2个按钮,它添加了111,
一个按钮增加11,
最后一个添加1?

解决方法

无法复制.我怀疑你是错误的 – 过度简化,主要是你的情况.确切地说,我相信你是动态地添加这些输入,并调用$(“.newContentLink”).每次点击(…) – 这当然是不断地将点击处理程序的附加副本应用到每个.newContentLink这一页.

因此,您创建的最近的输入有一个点击处理程序的副本,并附加一个1.第二个最近有两个副本并附加了11.第三个有三个并追加了111等.

为了防止这种情况,将点击处理程序应用到新创建的DOM元素,而不是$(“.newContentLink”)(这通常意味着每个.newContentLink).

原文地址:https://www.jb51.cc/jquery/180067.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐