首页 > 其他 > 详细

动态生成的标签绑定事件只能用一次的问题

时间:2018-02-28 16:11:33      阅读:123      评论:0      收藏:0      [点我收藏+]

在写一个待办事项项目时遇到一个问题。

原因

to-do list 里每一条任务都是动态的,在js里事先绑定好的点击事件会因为某一条任务的删除而失效,使得新添加的条目没有绑定点击事件,所以在使用中只能响应一次点击事件。

解决方法

可以使用事件代理的方法

 1 var list = $(".list");
 2 list.on("click", ".clear", function() { //为完成和删除按钮绑定事件
 3     var nowClickIndex = $(this).parent().find("i").text();
 4     deleteLS(who, nowClickIndex);
 5     appendToDOM(who);
 6 });
 7 /*****
 8  * 遇到的问题:
 9  * 绑定的事件只执行1次
10  * 原因:
11  * 使用的是$(".list-item").on("click", ".clear", function ()...
12  * 在dom重载后,$(".list-item")已经是新的了,原来的$(".list-item")消失,绑定的事件也随之消失
13  * 解决方法:
14  * $(".list-item")的父级元素没重载,用$(".list").on("click", ".clear", function ()...
15  * ******/

 

 

动态生成的标签绑定事件只能用一次的问题

原文:https://www.cnblogs.com/hibiki/p/8483787.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!