为什么我的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).

相关文章

页面搜索关键词突出 // 页面搜索关键词突出 $(function () {...
jQuery实时显示日期、时间 html: &lt;span id=&quot...
jQuery 添加水印 &lt;script src=&quot;../../../.....
中文:Sys.WebForms.PageRequestManagerParserErrorExceptio...
1. 用Response.Write方法 代码如下: Response.Write(&q...
Jquery实现按钮点击遮罩加载,处理完后恢复 思路: 1.点击按...