您的位置:首页 - 教程 - jQuery - 正文
jQuery DOM 操作(基本操作、内部插入、外部插入、包裹操作)
jQuery DOM 操作(基本操作、内部插入、外部插入、包裹操作)

jQuery操作DOM十分方便,有许多现成的方法。

以下为各种方法的示例和代码。

1.删除操作

(1)remove()

  $(selector).remove([selector])

 

$("#div3").remove(); //删除 id 为 div3 的 div 标签
$("div").remove("#div3"); //删除 div 标签中 id 为 "div3" 的标签



(2)detach()

  $(selector).detach([selector])

 

$("#div3").detach(); //删除 id 为 div3 的 div 标签
$("div").detach("#div3"); //删除 div 标签中 id 为 "div3" 的标签



(3)empty()

  $(selector).empty()

 

$("#div3").empty(); //删除 id 为 div3 的节点的所有子节点

    总结:remove 方法和 detach 方法的返回值均为被删除的jQuery节点对象,不同的是,前者指保留该对象节点本身,其他绑定的事件及附加的数据等都会被移除。而后者全部保留。empty 方法则是将指定节点的所有子节点删除,本身保留。

2.复制节点 clone()

  $(selector).clone([true]);

  带true参数则复制出来的节点具备原节点所绑定的事件处理程序。

3.替换节点

(1)replaceAll()

  $(content).replaceAll(selector);

(2)replaceWith()

  $(selector).repalceWith(content);

   这两种方法在使用时效果完全相同,都是用 content 代替 selector.

4.内部插入

  内部插入是将content插入到selector节点内部,包括内部的头部和尾部。插入后的节点与原节点是父子关系

(1)append()

  将content添加到seletor内部的头部。

  $(selector).append(content);

  $(selector).append(function(index [,html]){...});

  如果要获取selector的元素index及html内容,则采用第二种方法。调用的实例如下(html是可选参数):

 

 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
 <html>
 <head>
     <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
     <script src="../js/jquery-1.7.2.js" type="text/javascript"></script>
     <title>内部插入应用示例</title>
     <script language="javascript" type="text/javascript">
         $(document).ready(function(){
             $("#btn").click(function(){
                 //方法1   用 eq() 选择器找到指定节点
                 //$("div:eq(1)").append("<b>jQuery内部插入测试</b>");
                 //方法2   用函数的参数index索引值找到指定节点
                 $("div").append(function(index, html){
                     if(index == 1){
                         return "<b>jQuery内部插入测试</b>" + "  " + html;
                     }
                 });
             });
         });
     </script>
 </head>
 <body bgcolor="#EEEEEE">
     <h1>内部插入应用实例</h1>
     <div>
         <button id="btn">测试</button>
         <div id="div1">1.水果</div>
         <div id="div2">2.蔬菜</div>
         <div id="div3">3.肉类</div>
     </div>
 </body>
 </html>

    运行及点击测试按钮之后的效果如下:

                     

(2)appendTo()

  $(content).appendTo(selector);

(3)prepend()

  将content添加到seletor内部的尾部。

  $(selector).prepend(content);

  $(selector).prepend(function(index [,html]){...});

(4)prependTo()

  $(content).prependTo(selector);

    前两种方法效果相同,后两种方法效果相同。

5.外部插入

   外部插入是将content插入到selector节点外部,包括selector节点的前面和后面。插入后的节点与原节点是兄弟关系

(1)after()

  $(selector).after(content);

  $(selector).after(function(index [,html]){...});

(2)insetAfter()

  $(content).insertAfter(selector);

(3)before()

  $(selector).before(content);

  $(selector).before(function(index [,html]){...});

(4)insertBefore()

  $(content).insertBefore(selector);

  使用方法与内部插入类似。

6.包裹操作

(1)wrap()

  $(selector).wrap(wrapper);

  $(selector).wrap(function(){...});

  下面代码中的四种方法效果相同:

 

         $(document).ready(function(){
             $("#btn").click(function(){
                 var newNode = $("<b></b>");
                 //方法1
                 //$("#div2").wrap(newNode);
                 //方法2
                 //$("#div2").wrap("<b></b>");
                 //方法3
                 //$("#div2").wrap(document.createElement("b"));
                 //方法4
                 $("#div2").wrap(function(){
                     return "<b></b>";
                 });
             });
         });

(2)unwrap()

  $(selector).unwrap();

(3)wrapAll()

  $(selector).wrapAll(wrapper);

(4)wrapInner()

  $(selector).wrapInner(wrapper);

  $(selector).wrapInner(function(){...});

  总结:wrap() 和 wrapInner() 的显示效果相同,不同的是前者为 seletor 添加了父节点,而后者为 selector 添加了子节点。

              wrap() 和 wrapAll() 显示效果也相同,不同的是前者为 seletor 中的每一个子元素均添加父节点,而后者为整个 seletor 只添加一个父节点


评论: