zoukankan      html  css  js  c++  java
  • JQuery DOM 删除节点

    如果文档中某一个元素多余,那么应将其删除。JQuery提供了两种删除节点的方法,即remove()和empty()。

    HTML DOM结构如下:

    1 <p class="nm_p" title="欢迎访问简明现代魔法图书馆" >欢迎访问简明现代魔法图书馆</p>
    2 <ul class="nm_ul">
    3     <li title='PHP魔法'>简单易懂的PHP魔法</li>
    4     <li title='C魔法'>简单易懂的C魔法</li>
    5     <li title='JavaScript魔法'>简单易懂的JavaScript魔法</li>
    6     <li title='JQuery'>简单易懂的JQuery魔法</li>
    7

    </ul>

    remove()方法

    作用是从DOM中删除所有匹配的元素,传入的参数用于根据JQuery表达式来筛选元素。

    例如删除<ul>节点中的第2个<li>元素节点,JQuery代码如下:

    1 $(".nm_ul li:eq(1)").remove(); // 获取第二个<li>元素节点后,将它从网页中删除
    2 </li>

    运行代码后效果将删掉第二个节点。

    当某个节点用remove()方法删除后,该节点所包含的所有后代节点将同时被删除。这个方法的返回值是一个指向已被删除的节点的引用,因此可以在以后再使用这些元素。下面的JQuery代码说明元素用remove()方法删除后,还是可以继续使用的。

    1 var $li = $("nm_ul li:eq(1)").remove(); // 获取第二个<li>元素节点后,将它从网页中删除。  
    2 $li.appendTo("nm_ul");                     // 把刚才删除的又重新添加到<ul>元素里  
    3 //所以,删除只是从网页中删除,在jQuery对象中,这个元素还是存在的,我们可以重新获取它 

    可以直接使用appendTo()方法的特性来简化以上代码,JQuery代码如下:

    1 $("nm_ul li:eq(1)").appendTo("nm_ul");  
    2 //appendTo()方法也可以用来移动元素  
    3 //移动元素时首先从文档上删除此元素,然后将该元素插入得到文档中的指定节点

    另外remove()方法也可以通过传递参数来选择性地删除元素,JQuery代码如下:

    1 // 把<li>元素中属性title不等于"菠萝"的<li>元素删除
    2 $("nm_ul li").remove("li[title!=JQuery]");

    empty()方法

    严格来讲,empty()方法并不是删除节点,而是清空节点,它能清空元素中的所有后代节点。JQuery代码如下:

    1 $("nm_ul li:eq(1)").empty(); // 找到第二个<li>元素节点后,清空此元素里的内容

    当运行代码后,第2个<li>元素的内容被清空了,只剩下<li>标签默认的符号“.”。

  • 相关阅读:
    pycharm优化
    Shell基本命令
    Django项目订单接入支付宝
    浏览器的同源策略及跨域解决方案
    python datetime时区转换
    Django contenttypes 组件
    MySQL使用版本号实现乐观锁
    MySQL DDL Demo
    Redis分布式锁
    Zookeeper分布式锁
  • 原文地址:https://www.cnblogs.com/zqn518/p/2345631.html
Copyright © 2011-2022 走看看