jquery append 動態添加的元素事件on 不起作用的解決方案


用jquery添加新元素很容易,面對jquery append 動態添加的元素事件on 不起作用我們該如何解決呢?on方法中要先找到原選擇器(如例.info),再找到動態添加的選擇器(如列.delete)。

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>測試</title>
<script type="text/javascript"
src="../resources/js/jquery-1.11.1.min.js"></script>
<script type="text/javascript">
$(function(){
//動態添加
$(".add").on("click",function(){
console.log("進來了");
$(".info").append('<div class="delete"><h3>單擊我來刪除我</h3></div>');
});
 //對動態添加的元素添加事件-刪除
$(".info").on("click",".delete",function(){
console.log("進來了Delete!");
$(this).remove();
});
 }); 
</script>
 </head>
<body>
 <h2 class='add'>單擊我添加動態元素</h2>
 <div class="info"></div>
 </body>
</html>

注意:此遇到過這樣的問題,如果先有on中添加li事件,后用jquery添加 li ,此li將無事件,應該在on方法中要先找li父選擇器,再找到動態添加的選擇器li,這樣后添加的元素才會有事件。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM