亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

jQuery與原生JavaScript選擇HTML元素集合用法對比分析

 更新時間:2019年11月26日 09:09:19   作者:在線瘋狂  
這篇文章主要介紹了jQuery與原生JavaScript選擇HTML元素集合用法,結(jié)合實例形式對比分析了jquery與原生JavaScript選擇頁面HTML相關操作方法、注意事項及運行效率,需要的朋友可以參考下

本文實例講述了jQuery與原生JavaScript選擇HTML元素集合用法。分享給大家供大家參考,具體如下:

通過調(diào)用document.getElementsByTagName, document.getElementsByName以及document.getElementsByClassName(部分瀏覽器不支持),可以返回HTMLCollection對象。表面上,它們與數(shù)組很類似,因為它們都包含length屬性并且元素都可以通過[index]方式訪問。然而,實際上它們并不是數(shù)組;諸如push(), slice()與sort()之類的方法不受支持。

考慮下面的HTML文檔:

<body>
  <p>Paragraph 1</p>
  <p>Paragraph 2</p>
  <p>Paragraph 3</p>
</body>

我們使用原生JavaScript的getElementsByTagName方法與jQuery選擇器分別獲取每一個paragraph節(jié)點:

var pCollection = document.getElementsByTagName("p");
var pQuery = $("p");
console.log("pCollection.length: ", pCollection.length);
console.log("pQuery.length: ", pQuery.length);

它們都返回了相同的節(jié)點,因此集合長度都是3:

pCollection.length: 3
pQuery.length: 3

我們現(xiàn)在再向文檔中添加一個paragraph元素,然后再觀察一下集合:

// add new paragraph
var newp = document.createElement("p");
newp.appendChild(document.createTextNode("Paragraph 4"));
document.body.appendChild(newp);
// 
// display length
console.log("pCollection.length: ", pCollection.length);
console.log("pQuery.length: ", pQuery.length);

運行結(jié)果:

pCollection.length: 4
pQuery.length: 3

HTMLCollection對象是實時的(live)。它們會在相應文檔發(fā)生變化時自動更新。jQuery與其他JavaScript庫也使用了諸如document.getElementsByTagName()之類的方法,但是將返回的節(jié)點拷貝到一個真正的數(shù)組里面。因此,查詢得到的結(jié)果反映的是文檔當時的狀態(tài):而不會隨著文檔的變化自動更新。

兩種方法各有利弊。例如,下面的代碼會導致無限循環(huán),因為HTMLCollection的長度會在<p>元素增加時自動+1:

var pCollection = document.getElementsByTagName("p");
for (var i = 0; i < pCollection.length; i++) {
  document.body.appendChild(pCollection[i].cloneNode(true));
}

有時候,相較于靜態(tài)的jQuery節(jié)點集合或者重復調(diào)用選擇器,使用速度更快、原生的實時HTMLCollection更合適。幸運的是,我們可以在需要時方便地將任何集合傳遞給jQuery,例如:

var pCollection = document.getElementsByTagName("p");
// ... add nodes, do work, etc ...
$(pCollection).addClass("myclass");

jQuery與其他庫可以減少開發(fā)工作量,但是,在可能的情況下,使用原生(plain old)JavaScript,可以避免額外的文件請求與處理開銷,從而寫出更加高效的代碼。

原文鏈接:http://www.sitepoint.com/javascript-vs-jquery-html-collections/

感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運行工具http://tools.jb51.net/code/HtmlJsRun測試上述代碼運行效果。

更多關于JavaScript相關內(nèi)容可查看本站專題:《JavaScript操作DOM技巧總結(jié)》、《JavaScript頁面元素操作技巧總結(jié)》、《JavaScript事件相關操作與技巧大全》、《JavaScript查找算法技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript錯誤與調(diào)試技巧總結(jié)

希望本文所述對大家JavaScript程序設計有所幫助。

相關文章

最新評論