http://www.polarxiong.com/archives/jQuery-Ajax%E5%8A%A8%E6%80%81%E5%8A%A0%E8%BD%BD%E5%86%85%E5%AE%B9on-%E7%BB%91%E5%AE%9A%E4%BA%8B%E4%BB%B6%E6%97%A0%E6%95%88%E7%9A%84%E8%A7%A3%E5%86%B3%E6%96%B9%E6%B3%95.html
1.Problem:
- 新增的『元素』讀取不到『事件』
2.Example:
- new botton 綁定『click』事件 → 出現 alert()
- 但只有寫死的有效,動態加載的卻失效
- 舉例:
<!doctype html> <html> <head> <meta charset="utf-8"> <link rel="stylesheet" href="cssName.css"> <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script> <title>aaa</title> <script> $(function(){ $('#btn').click(function(){ $('#the_div').append('<button>new button</button>'); }) $("#the_div button").click(function(){ alert('clicked'); }) }); </script> </head> <body> <div id="the_div"> <button>new button</button> </div> <button id="btn">test</button> </body>
3.Why
- 第一次$(function(){}) 載入html時,只有寫死的new botton有被『註冊』
- 後面動態加載的並沒有被載入
4.Solution
- 使用.on方式
- $( document ).on( events, selector, data, handler );
- 舉例,將方法置換成下列程式
$(document).on('click','#the_div button',function(){ alert('clicked'); })
沒有留言:
張貼留言