JS中的DOM— —節點以及操作
DOM操作在JS中可以說是非常常見了吧,很多網頁的小功能的實現,比如一些元素的增刪操作等都可以用JS來實現。那麼在DOM中我們需要知道些什麼才能完成一些功能的實現呢?今天這篇文章就先簡單的帶大家入一下JS中DOM操作的門吧!!
一、DOM樹的節點
1、 DOM節點分為三大類: 元素節點(標籤節點)、屬性節點和文字節點。
屬性節點和文字節點都屬於元素節點的子節點。 因此操作時,需先選中元素節點,再修改屬性和文字。
【檢視元素節點】
1、 使用getElement系列方法:
具體的HTML程式碼如下圖:
//透過ID來檢視元素屬性var li = document.getElementById("first"); //透過類名來檢視元素屬性var lis1 = document.getElementsByClassName("cls");//透過名字來檢視元素屬性var lis2 = document.getElementsByName("name");//透過標籤名來檢視元素屬性var lis3 = document.getElementsByTagName("li");
注意事項:
① ID不能重名,如果ID重複,只能取到第一個。
② 獲取元素節點時,必須等到DOM樹載入完成後才能獲取。
兩種處理方式: a.將JS寫在文件最後;
b.將程式碼寫入window.onload函式中;
③ 透過getElements系列取到的為陣列格式,操作時必須取到其中的每一個元素,才能進行操作,而不能直接對陣列進行操作。
document.getElementsByTagName("li")[0].click = function(){}
④ 這一系列方法,也可以先選中一個DOM節點,在從選中的DOM節點中,選擇需要的節點:
document.getElementById("div1").getElementsByTagName("li");
【透過querySelector系列方法】
① 傳入一個選擇器名稱,返回第一個找到的元素。 通常用於查詢ID:
var dq1 = document.querySelector("#id");
② 傳入一個選擇器名稱,返回所有找到的元素,無論找到幾個,都返回陣列格式。這種方法比較全能,不管什麼屬性都可以準確地找到。
var dqs1 = document.querySelectorAll("#div1 li");
【檢視設定屬性節點】
1、 檢視屬性節點:.getAttribute("屬性名");
2、 設定屬性節點:.setAttribute("屬性名","屬性值");
注意事項:.setAttribute() 在老版本IE中會存在相容性問題,可以使用.符號代替。
【JS修改CSS的多種方式】
1、 使用setAttribute設定class和style。
document.getElementById("first").setAttribute("class","class1"); document.getElementById("first").setAttribute("style","color:red;");
2、使用.className新增一個class選擇器。
document.getElementById("first").className = "class1";
3、 使用.style.樣式 直接修改單個樣式。 注意樣式名必須使用駝峰命名法。
document.getElementById("first").style.fontSize = "18px";
4、 使用.style 或 .style.cssText 新增一序列級樣式:
// IE不相容document.getElementById("first").style = "color:red;"; //所有瀏覽器相容document.getElementById("first").style.cssText = "color:red;";
【檢視/設定文字節點】
1、.innerHTML: 取到或設定一個節點中的HTML程式碼。
2、.innerText: 取到或設定一個節點中的文字,不能設定HTML程式碼。
二、層次節點操作
1. .childNodes: 獲取當前節點的所有子節點(包括元素節點和文字節點)。
.children: 獲取當前節點的所有元素子節點(不包含文字節點)。
2. .parentNode: 獲取當前節點的父節點。
3. .firstChild: 獲取第一個子節點,包括回車等文字節點;
.firstElementChild: 獲取第一個元素節點。 不含文字節點;
.lastChild: 獲取最後一個子節點,包括回車等文字節點;
.lastElementChild: 獲取最後一個子節點,不含文字節點;
4. .previousSibling: 獲取當前節點的前一個兄弟節點,包括文字節點;
.previousElementSibling: 獲取當前節點的前一個元素兄弟節點;
.nextSibling:獲取當前節點的後一個兄弟節點,包括文字節點;
.nextElementSibling:獲取當前節點的後一個元素兄弟節點;
5. .attributes: 獲取當前節點的所有屬性節點。 返回陣列格式。
【建立並新增節點】
1. document.createElement("標籤名"): 建立一個新節點,並將建立的新節點返回。
需要配合.setAttribute()為新節點設定屬性。
2. 父節點.insertBefore(新節點,目標節點): 在父節點中,將新節點插入到目標節點之前。
父節點.appendChild(新節點): 在父節點的內部最後,插入一個新節點。
3. 源節點.cloneNode(true): 克隆一個節點。
傳入true表示克隆源節點以及源節點的所有子節點;
傳入false或不傳,表示只克隆當前節點,而不克隆子節點。
【刪除、替換節點】
1. 父節點.removeChild(子節點): 從父節點中,刪除指定子節點。
2. 父節點.replaceChild(新節點,老節點): 從父節點中,用新節點替換老節點。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/2471/viewspace-2800816/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- js中dom節點刪除remove方法JSREM
- 原生JS中DOM節點相關API合集JSAPI
- jQuery操作dom節點empty()方法jQuery
- JavaScript學習之DOM(節點、節點層級、節點操作)JavaScript
- js的dom操作JS
- js判斷dom節點是否存在JS
- JS中DOM操作總結JS
- js獲取dom節點的方法有哪些JS
- jquery中dom節點操作方法empty和remove的區別jQueryREM
- js原生節點操作JS
- 請說說DOM節點的操作如何最佳化?
- 原生JS 操作 DOMJS
- jQuery關於DOM操作節點一些方法jQuery
- js用字首名查詢class或id節點,js模糊查詢某個dom節點JS
- js中為什麼dom操作消耗效能JS
- JS中的DOMJS
- dom節點和vue中template淺談Vue
- jquery 中的dom操作jQuery
- jQuery中的DOM操作jQuery
- react中的DOM操作React
- <react學習筆記(7)>操作DOM節點,元件傳參React筆記元件
- DOM節點的種類有哪些?
- XML DOM 新增節點概述XML
- JavaScript的字串、陣列以及DOM操作總結JavaScript字串陣列
- 使用jaxp解析器dom方式對xml節點進行操作XML
- Tree元件的快速定位更新節點的狀態,以及修改節點的資料屬性等操作元件
- 軟體測試:DOM節點
- XML DOM 替換節點概述XML
- XML DOM 刪除節點概述XML
- Web全棧20201128-js的dom操作1Web全棧JS
- python中pyquery無法獲取標籤名的dom節點Python
- JS錯誤記錄 – dom操作 – 排序JS排序
- JS知識總結之DOM操作JS
- 處理尚不存在的 DOM 節點
- js中DOM總結JS
- DOM節點刪除方法小結
- JS 操作 DOM 改變方塊顏色JS
- 圍繞DOM元素節點的增刪改查