.parent.html("")和.detach()的區(qū)別
都是不清空已注冊的事件吧 然而我這么寫就無法調(diào)用事件了
<html> <head> ????<meta?http-equiv="Content-type"?content="text/html;?charset=utf-8"?/> ????<script?src="http://lib.sinaapp.com/js/jquery/1.9.1/jquery-1.9.1.min.js"></script> ????<style?type="text/css"> ????p?{ ????????color:?red; ????} ????</style> </head> <body> ????<div> ????<p>P元素1,默認(rèn)給綁定一個點(diǎn)擊事件</p> ????<p>P元素2,默認(rèn)給綁定一個點(diǎn)擊事件</p> ????</div> ????<button?id="bt1">點(diǎn)擊刪除?p?元素</button> ????<button?id="bt2">點(diǎn)擊移動?p?元素</button> ????<script?type="text/javascript"> ????$('p').click(function(e)?{ ????????alert(e.target.innerHTML) ????}) ????var?p; ????$("#bt1").click(function()?{ ????????if?(!$("p").length)?return;?//去重 ????????//通過detach方法刪除元素 ????????//只是頁面不可見,但是這個節(jié)點(diǎn)還是保存在內(nèi)存中 ????????//數(shù)據(jù)與事件都不會丟失 ????????p?=?$("p"); ????????$("p").parent().html(""); ????}); ????$("#bt2").click(function()?{ ????????//把p元素在添加到頁面中 ????????//事件還是存在 ????????$("div").append(p); ????}); ????</script> </body> </html>
2017-06-20
p并不是指向內(nèi)存堆中原來的jQuery對象
你可以試下console.log(p==$("p")) ?//返回值false
2017-06-17
js中 參數(shù)是按值傳遞 而不是按引用地址傳遞 ?你給$('p')這個jQuery對象綁定了事件,并沒有給p綁定事件。