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

前端之家收集整理的这篇文章主要介绍了为什么我的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.f2er.com/jquery/180067.html

猜你在找的jQuery相关文章