1. 程式人生 > >jquery動態新增元素無法觸發繫結的事件的解決方案。

jquery動態新增元素無法觸發繫結的事件的解決方案。

  最近遇到一個問題,即當用jquery動態新增元素後,發現給動態新增的元素卻無法觸發事件。後來在網上查閱了一些資料,發現原來要這樣處理:

  先上我出錯的程式碼:
  

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
    <link rel="stylesheet" href="http://cdn.bootcss.com/bootstrap/3.3.0/css/bootstrap.min.css"
>
<script src="//cdn.bootcss.com/jquery/1.8.3/jquery.min.js"></script> <script> $(document).ready(function(){         //這裡是動態新增元素 $(".add").click(function(){ var btn = $("<button class='newBtn btn btn-default'>新按鈕</button>"); $("body"
).append(btn); })<br><br>        //這裡是為新增的元素新增事件 $(".newBtn").click(function(){ alert("這裡是新新增的元素觸發的事件"); }) })
</script> </head> <body> <button class=" add btn btn-default">新增按鈕</button> </body>
</html>

  奉上我的解決方法
  方法一:繫結live事件(live事件只在jquery1.9以下才支援,高版本不支援)。
  

$(".newBtn").live("click",function(){ ///jquery 1.9(不包括1.9)以下可以
   alert('這裡是動態元素新增的事件');
 })

  方法二:利用on()事件繫結
  ($(ParentEle).on("click",".thisEle",function(){})
  

$("body").on("click", ".newBtn", function() {
              alert('這裡是動態元素新增的事件');
          });//這裡的ParentEle是 thisEle的父輩元素或者祖先元素,ParentEle可以是document,也可以是body等。<br><br><br>//注意:如果此時呼叫的函式是外部定義好的函式,那在呼叫的時候不要加(),不然會跳過點選事件直接觸發函式
$("body").on("click", ".newBtn",aa );
 function aa(){
        alert('這裡是動態元素新增的事件');
  }

  ok,問題解決,繼續爬坑。