详细解释一下jQuery中detach()的用法?
看了w3c的文档,不是很明白啊,谁给我举个例子说一下?谢谢!还有这里本身有个例子:<html><head><scripttype="text/javascript"src...
看了w3c的文档,不是很明白啊,谁给我举个例子说一下?谢谢!
还有这里本身有个例子:
<html>
<head>
<script type="text/javascript" src="/jquery/jquery.js"></script>
<script type="text/javascript">
$(document).ready(function(){
$("button").click(function(){
$("body").append($("p").detach());
});
});
</script>
</head>
<body>
<p>This is a paragraph.</p>
<button>移动 p 元素</button>
</body>
</html>
这怎么一点按钮p就到按钮下面去了呢? 展开
还有这里本身有个例子:
<html>
<head>
<script type="text/javascript" src="/jquery/jquery.js"></script>
<script type="text/javascript">
$(document).ready(function(){
$("button").click(function(){
$("body").append($("p").detach());
});
});
</script>
</head>
<body>
<p>This is a paragraph.</p>
<button>移动 p 元素</button>
</body>
</html>
这怎么一点按钮p就到按钮下面去了呢? 展开
4个回答
展开全部
detach从字面上就很容易理解。
让一个web元素托管。
即从当前页面中移除该元素,但保留这个元素的内存模型对象。
来看看jquery官方文档的解释:
这个方法不会把匹配的元素从jQuery对象中删除,因而可以在将来再使用这些匹配的元素。与remove()不同的是,所有绑定的事件、附加的数据等都会保留下来。
$("p").detach()这一句会移除对象,仅仅是显示效果没有了。但是内存中还是存在的。当你append之后,又重新回到了文档流中。就又显示出来了。
虽然这个方法我不常用。但是可以预测的是。使用getElementsByTagName应该匹配不到当前元素了。因为元素已经脱离了文档流。之所以这个元素没有被当做垃圾回收。是因为被jquery托管了。jquery继续引用着当前这个元素。这个元素就不会被垃圾回收器当做垃圾对象从内存中移除。
让一个web元素托管。
即从当前页面中移除该元素,但保留这个元素的内存模型对象。
来看看jquery官方文档的解释:
这个方法不会把匹配的元素从jQuery对象中删除,因而可以在将来再使用这些匹配的元素。与remove()不同的是,所有绑定的事件、附加的数据等都会保留下来。
$("p").detach()这一句会移除对象,仅仅是显示效果没有了。但是内存中还是存在的。当你append之后,又重新回到了文档流中。就又显示出来了。
虽然这个方法我不常用。但是可以预测的是。使用getElementsByTagName应该匹配不到当前元素了。因为元素已经脱离了文档流。之所以这个元素没有被当做垃圾回收。是因为被jquery托管了。jquery继续引用着当前这个元素。这个元素就不会被垃圾回收器当做垃圾对象从内存中移除。
展开全部
首先,你通过$("p").detach()把上面的p给“删除/隐藏”了,实际上p还是存在的,只是你看不到了。
然后你又用
$("body").append($("p").detach());
向body中添加元素,这个元素其实还是p。
不是p跑到下面,而是你把p给“复制”了一个并添加到最下面,原来的p给隐藏了。
然后你又用
$("body").append($("p").detach());
向body中添加元素,这个元素其实还是p。
不是p跑到下面,而是你把p给“复制”了一个并添加到最下面,原来的p给隐藏了。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
detach的作用不同与remove,detach删除元素后,可保存在临时变量中,需要的时候可以再次添加。
上述代码的含义是当单击按钮时,删除p元素后,再添加到页面的末尾。
我这样表述不知您明白吗?
上述代码的含义是当单击按钮时,删除p元素后,再添加到页面的末尾。
我这样表述不知您明白吗?
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
楼上是说的对的。楼主其实把$("body").append($("p").detach());改为$("p").detach()看看效果,就会发现其实就是删除匹配元素,这是我们看到的,内存实际是存在的。他这里的作用就是为了服务于append。追加元素,在已有的页面显示基础上<button>移动 p 元素</button>,后面追加刚刚在内存中保留的<p>This is a paragraph.</p>。在实际应用上隐藏/显示作用
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询