jQuery操作DOM元素


jQuery操作DOM元素

  HTML DOM常見操作:
  查找節點,插入節點,刪除節點,復制節點,替換節點,包裹節點.
 

查找節點

  關於節點的查找,是利用選擇器完成的.
  在上一篇jQuery選擇器中已經介紹過了:http://www.cnblogs.com/mengdd/p/4211663.html
 

插入節點

  首先看一個例子,用原生的JavaScript如何創建並添加元素:
<!DOCTYPE html>
<html>
<head>
    <script>

        var addItems = function(){
            var number = parseInt(document.getElementById("number").value);
            var div1 = document.getElementById("div1");

            div1.innerHTML = "";//clear div before append

            for(var i = 0; i < number; ++i){
                var input = document.createElement("input");
                input.setAttribute("type","text");
                var br = document.createElement("br")
                div1.appendChild(input);
                div1.appendChild(br);
            }
        }

    </script>
</head>
<body>
<input type="text" id="number"/>
<input type="button" id="btn" value="Click" onclick="addItems();"/>
<div id="div1">
</div>
</body>
</html>
 
  jQuery插入元素的方法:
  append(): 向每個匹配的元素內部追加內容.
  appendTo(): 將所有匹配的元素追加到指定的元素中,即$(A).appendTo(B),是將A追加到B中.
  prepend(): 向每個匹配的元素內部前置內容.
  prependTo(): 將所有匹配的元素前置到指定的元素中,即$(A).prependTo(B),是將A前置到B中.
 
  前面幾個方法都是插入子元素,后面的這幾個方法是插入兄弟元素.
  after(): 在每個匹配的元素之后插入內容.
  insertAfter(): 將所有匹配的元素插入到指定元素的后面.
  before(): 在每個匹配的元素之前插入內容.
  insertBefore(): 將所有匹配的元素插入到指定元素的前面.
 
  jQuery支持方法鏈式的調用,即append()等方法返回的仍然是這個jQuery對象,后面可以繼續調用append()方法.
 
  下面我們將開始的那個例子用jQuery實現:
<!DOCTYPE html>
<html>
<head>
    <script src="/jquery/jquery-1.11.1.min.js">
    </script>
    <script>

        var addItems = function(){
            var number = parseInt($("#number").val());
            var div1 = $("#div1");

            div1.html("");//clear div before append

            var string = "";
            for(var i = 0; i < number; ++i){
                string += "<input type='text'/><br/>"
            }
            div1.append(string);
        }

    </script>
</head>
<body>
<input type="text" id="number"/>
<input type="button" id="btn" value="Click" onclick="addItems();"/>
<div id="div1">
</div>
</body>
</html>
 
  插入已有節點->移動節點
  除了可以插入新建的節點之外,還可以選擇已有節點,插入到別的地方,以完成節點的移動操作.
  注意這里是移動操作,即原來的節點會改變位置:
<!DOCTYPE html>
<html>
<head>
<script src="/jquery/jquery-1.11.1.min.js">
</script>
<script>
$(document).ready(function(){

$("ul li:eq(0)").appendTo("ul");

});
</script>
</head>
<body>
<ul>
<li title="li1">1</li>
<li title="li2">2</li>
<li title="li3">3</li>
<li title="li4">4</li>
<li title="li5">5</li>
</ul>
</body>
</html>
 
  運行結果為:
 

刪除節點

  jQuery中刪除節點的方法:
  remove(): 移除所有匹配的元素.
  empty(): 刪除匹配的元素集合中所有內容,包括子節點.注意,元素本身沒有被刪除.
 
  關於remove()方法,有幾點需要說明一下:
  1.remove()方法的返回值:
  remove()方法會返回被刪除節點的jQuery對象.可以把這個對象插入到其他的地方.
  所以也可以用這種方法來移動節點:
<!DOCTYPE html>
<html>
<head>
<script src="/jquery/jquery-1.11.1.min.js">
</script>
<script>
$(document).ready(function(){

$("ul li:eq(0)").appendTo("ul");//move li method1

//move method2:
var removeLi = $("ul li:eq(0)").remove();//delete li
removeLi.appendTo($("ul"));//add removed li


});
</script>
</head>
<body>
<ul>
<li title="li1">1</li>
<li title="li2">2</li>
<li title="li3">3</li>
<li title="li4">4</li>
<li title="li5">5</li>
</ul>
</body>
</html>

運行結果為:
  注意直接寫標簽名(例如:appendTo(“ul”))和取jQuery對象(例如:appendTo($(“ul")))的結果一樣.
 
  2.remove()方法的參數:
  remove()方法默認情況下會刪除選擇器選中的所有元素.
  比如下面的代碼將刪除所有<ul>下的<li>:
//remove all li
$("ul li").remove();
 
        
  remove()方法還可以接收參數,設置一些篩選條件,指定到底要刪除其中的哪些節點.
  比如除了指定title的,其他全部移除:
//remove some
$("ul li").remove("li[title!='li2']");

 

   empty()方法:刪除匹配元素集合中的所有子節點,清空內容.但是元素本身還存在.
  比如:
//empty children
$("ul").empty();

  會刪除<ul>中的所有子節點.

  而:
//empty content
$("ul li:eq(3)").empty();

  會得到這樣的效果:

 
 

復制節點

  jQuery中復制節點的方法:
  clone(): 創建匹配元素集合的副本.
  clone()方法返回被復制的節點.
  看一個例子,每次點擊<li>都復制同樣的元素並添加在<ul>末尾:
<!DOCTYPE html>
<html>
<head>
<script src="/jquery/jquery-1.11.1.min.js">
</script>
<script>
$(document).ready(function(){
$("ul > li").click(function(){
$(this).clone().appendTo("ul");
});
});
</script>
</head>
<body>
<ul>
<li title="li1">1</li>
<li title="li2">2</li>
<li title="li3">3</li>
<li title="li4">4</li>
<li title="li5">5</li>
</ul>
</body>
</html>
 
  注意,clone出來的<li>對象就沒有click事件了,即點擊復制添加出來的<li>,不會再添加新的<li>.
 
  jQuery考慮到有時候會有需要clone所有的事件,所以clone方法可以帶一個參數.
  clone(true): 復制節點,包括所有的事件處理.
  clone(false): 復制節點,但不包括事件處理.不帶參數時默認是這種情況.
 
 

替換節點

  jQuery中替換節點的方法:
  replaceAll(): 用指定的HTML內容或元素替換被選元素.
  語法: $(content).replaceAll(selector).
  replaceWith(): 用新內容替換所匹配到的元素.
  語法: $(selector).replaceWith(content).
 
  其中的content可以是HTML代碼,可以是新元素,也可以是已經存在的元素.
 
  關於用已有元素替換:
  "已經存在的元素不會被移動,只會被復制."這種說法是不正確的.
 
  實際做了實驗之后,發現用已有元素替換,原來的元素是會被移除的:
<html>
<head>
<script type="text/javascript" src="/jquery/jquery.js"></script>
<script type="text/javascript">
$(document).ready(function(){
$("#button1").click(function(){
alert("click event");
$("#button1").replaceAll($("div"));

});
});
</script>
<style>
div{height:20px;background-color:yellow}
</style>
</head>
<body>
<p>
This is paragraph:
<div id="div1">This is a div 1</div>
<div id="div2">This is a div 2</div>
<p>
This is button area:
<br><button id="button1" class="btn1">Button1</button>


</body>
</html>
 
        
  頁面初始狀態:
  點擊按鈕之后:
  點擊新得到的兩個Button1,是可以彈出alert的,說明替換節點的時候連同節點事件一起放到了新的地方.
 
  查看官方文檔:
  replaceAll(): http://api.jquery.com/replaceAll/
  replaceWith(): http://api.jquery.com/replaceWith/
  可以看到使用已有節點是不會復制該節點的,而是會移動該節點到新的地方.
 
 

包裹節點

  包裹節點,意思是把匹配的元素用指定的內容或者元素包裹起來,即增加一個父元素.
  方法有:
  wrap(): 把匹配的元素用指定的內容或元素包裹起來.
  wrapAll(): 把所有匹配的元素用指定的內容或元素包裹起來,這里會將所有匹配的元素移動到一起,合成一組,只包裹一個parent.
  wrapInner(): 將每一個匹配元素的內容用指定的內容或元素包裹起來.
 
  例子代碼:
<html>
<head>
<script type="text/javascript" src="/jquery/jquery.js"></script>
<script type="text/javascript">
$(document).ready(function(){
$("#button1").click(function(){
$("#div1").wrap("<a href='www.google.com'>Google Wrap div1</a>");
});
$("#button2").click(function(){
$("div").wrapAll("<a href='www.baidu.com'>Baidu Wrap all div</a>");
});
$("#button3").click(function(){
$("div").wrapInner("<a href='www.sogou.com'>Sogou Wrap inner div</a>");
});
});
</script>
<style>
div{height:20px;background-color:yellow}
</style>
</head>
<body>
div1:<br/><div id="div1">This is a div 1</div>
div2:<br/><div id="div2">This is a div 2</div>
div3:<br/><div id="div3">This is a div 3</div>
This is button area:
<br/><button id="button1">Wrap</button>
<br/><button id="button2">Wrap All</button>
<br/><button id="button3">Wrap Inner</button>
</body>
</html>

 

   頁面初始狀態:
 
  按第一個按鈕,wrap特定的一個div:
 
  
  在按了第一個按鈕之后,按第二個按鈕,wrapAll將所有的div包裹進一個group:
 
 
  按了第一個按鈕和第二個按鈕之后,按第三個按鈕,wrapInner,在每一個div內部添加一層嵌套:
 
 
 
 
 

相關雜項知識

  1.關於變量命名的一點題外話:
  變量命名習慣(不是標准):
  var $v jQuery對象變量以$符號開頭命名.
  var v 普通HTML DOM對象變量.
  但是個人覺得初學者用這樣的命名可能會有點混亂,會比較難以區分什么時候是命名,什么時候是jQuery操作符.
  所以目前的例子里先不這樣用.
 
  2.小知識: 在HTML標簽的字符串前面加上$符號即可將其轉換為jQuery對象,比如:
  var child = $("<input type='text'/><br/>");
 
  3.從第一個例子可以看出,JavaScript操縱DOM元素的方法和jQuery的相關方法名稱區別如下:
  JavaScript: appendChild(), removeChild().
  jQuery: append(), remove(). 不過這個remove()移除的是自身.
 
 
 
 

參考資料

  聖思園張龍老師JavaWeb視頻教程72
  jQuery API Document: http://api.jquery.com/
 
  w3school jQuery參考手冊:
  w3school文檔中有些地方說的不太對,建議細節部分還是看官方API文檔.


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM