欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript DOM節(jié)點(diǎn)操作方法總結(jié)

 更新時(shí)間:2016年08月23日 10:34:58   投稿:jingxian  
下面小編就為大家?guī)?lái)一篇JavaScript DOM節(jié)點(diǎn)操作方法總結(jié)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

節(jié)點(diǎn)類(lèi)型主要有三種:元素節(jié)點(diǎn),屬性節(jié)點(diǎn)和文本節(jié)點(diǎn)。

而對(duì)DOM的主要也就是圍繞元素節(jié)點(diǎn)和屬性節(jié)點(diǎn)增刪改查。下面就分別從對(duì)元素節(jié)點(diǎn)的操作和對(duì)屬性節(jié)點(diǎn)的操作來(lái)介紹。

元素節(jié)點(diǎn)

在對(duì)DOM進(jìn)行增刪改之前,首先要找到對(duì)應(yīng)的元素。具體的查找方法如下:

getElementByID()       // 得到單個(gè)節(jié)點(diǎn)
 getElementsByTagName()    // 得到節(jié)點(diǎn)數(shù)組 NodeList
 getElementsByName()      // 得到節(jié)點(diǎn)數(shù)組 NodeList

同時(shí)還可以利用元素節(jié)點(diǎn)的屬性獲取它的父子節(jié)點(diǎn)和文本節(jié)點(diǎn):

子節(jié)點(diǎn)

 

Node.childNodes  //獲取子節(jié)點(diǎn)列表NodeList; 注意換行在瀏覽器中被算作了text節(jié)點(diǎn),如果用這種方式獲取節(jié)點(diǎn)列表,需要進(jìn)行過(guò)濾
Node.firstChild  //返回第一個(gè)子節(jié)點(diǎn)
Node.lastChild  //返回最后一個(gè)子節(jié)點(diǎn)

 父節(jié)點(diǎn)

Node.parentNode   // 返回父節(jié)點(diǎn)
Node.ownerDocument  //返回祖先節(jié)點(diǎn)(整個(gè)document)

同胞節(jié)點(diǎn)

Node.previousSibling    // 返回前一個(gè)節(jié)點(diǎn),如果沒(méi)有則返回null
Node.nextSibling       // 返回后一個(gè)節(jié)點(diǎn)

新增節(jié)點(diǎn)首先要?jiǎng)?chuàng)建節(jié)點(diǎn),然后將新建的節(jié)點(diǎn)插入DOM中,所以下面分別介紹創(chuàng)建節(jié)點(diǎn)和插入節(jié)點(diǎn)的方法,復(fù)制節(jié)點(diǎn)的方法也在創(chuàng)建節(jié)點(diǎn)中進(jìn)行介紹。

創(chuàng)建節(jié)點(diǎn)

createElement()    // 按照指定的標(biāo)簽名創(chuàng)建一個(gè)新的元素節(jié)點(diǎn)

創(chuàng)建代碼片段(為避免頻繁刷新DOM,可以先創(chuàng)造代碼片段,完成所有節(jié)點(diǎn)操作之后統(tǒng)一添加到DOM中)

createDocumentFragment()

復(fù)制節(jié)點(diǎn)

clonedNode = Node.cloneNode(boolean) // 只有一個(gè)參數(shù),傳入一個(gè)布爾值,true表示復(fù)制該節(jié)點(diǎn)下的所有子節(jié)點(diǎn);false表示只復(fù)制該節(jié)點(diǎn)

插入節(jié)點(diǎn)

/*插入node*/
parentNode.appendChild(childNode);  // 將新節(jié)點(diǎn)追加到子節(jié)點(diǎn)列表的末尾
parentNode.insertBefore(newNode, targetNode);  //將newNode插入targetNode之前

/*插入html代碼*/
node.insertAdjacentHTML('beforeBegin', html);  //在該元素之前插入代碼
node.insertAdjacentHTML('afterBegin', html);  //在該元素的第一個(gè)子元素之前插入代碼
node.insertAdjacentHTML('beforeEnd', html);  //在該元素的最后一個(gè)子元素之后插入代碼
node.insertAdjacentHTML('afterEnd', html);  //在該元素之后插入代碼

替換節(jié)點(diǎn)

parentNode.replace(newNode, targetNode);    //使用newNode替換targetNode

移除節(jié)點(diǎn)

parentNode.removeChild(childNode);  // 移除目標(biāo)節(jié)點(diǎn)
node.parentNode.removeChild(node);    //在不清楚父節(jié)點(diǎn)的情況下使用

屬性節(jié)點(diǎn)

操作屬性節(jié)點(diǎn),就是對(duì)DOM樣式進(jìn)行增刪改查。對(duì)于行內(nèi)樣式、內(nèi)聯(lián)樣式、外部樣式有不同的操作方法;各種方法獲得的樣式也有可讀可寫(xiě)和只讀之分。

直接獲取CSS樣式

node.style.color     // 可讀可寫(xiě)

Style本身的屬性和方法

node.style.cssText     //獲取node行內(nèi)樣式字符串
node.style.length      //獲取行內(nèi)樣式個(gè)數(shù)
node.style.item(0)     //獲取指定位置的樣式

獲取和修改元素樣式

HTML5為元素提供了一個(gè)新的屬性:classList 來(lái)實(shí)現(xiàn)對(duì)元素樣式表的增刪改查。操作如下:

node.classList.add(value);     //為元素添加指定的類(lèi)
node.classList.contains(value);  // 判斷元素是否含有指定的類(lèi),如果存在返回true
node.classList.remove(value);  // 刪除指定的類(lèi)
node.classList.toggle(value);  // 有就刪除,沒(méi)有就添加指定類(lèi)

修改DOM特性的方法

Node.getAttribute('id')    // 獲取
Node.setAttribute('id')    // 設(shè)置
Node.removeAttribute()     // 移除
Node.attributes        // 獲取DOM全部特性

只讀方法

getComputedStyle是window的方法。它能夠獲取當(dāng)前元素所有最終使用的CSS屬性值,但是是只讀的。它有兩個(gè)參數(shù),第一個(gè)為傳入的節(jié)點(diǎn),第二個(gè)可以傳入:hover, :blur等獲取其偽類(lèi)樣式,如果沒(méi)有則傳入null。

然而IE并不支持getComputedStyle方法,可以使用currentStyle來(lái)保持兼容性:

window.getComputedStyle ? window.getComputedStyle(node, null) : node.currentStyle

以上這篇JavaScript DOM節(jié)點(diǎn)操作方法總結(jié)就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • JavaScript跨平臺(tái)的開(kāi)源框架NativeScript

    JavaScript跨平臺(tái)的開(kāi)源框架NativeScript

    本文給大家分享的是一款使用javascript來(lái)構(gòu)建跨平臺(tái)原生移動(dòng)應(yīng)用的開(kāi)源框架--NativeScript,可以使用JavaScript開(kāi)發(fā)跨平臺(tái)、真正原生的iOS, Android 和 Windows 移動(dòng)App。開(kāi)發(fā)人員使用NativeScript提供的庫(kù)來(lái)構(gòu)建應(yīng)用UI,其抽象了各種原生平臺(tái)之間的不同。
    2015-03-03
  • js通過(guò)var定義全局變量與在window對(duì)象上直接定義屬性的區(qū)別說(shuō)明

    js通過(guò)var定義全局變量與在window對(duì)象上直接定義屬性的區(qū)別說(shuō)明

    這篇文章主要介紹了js通過(guò)var定義全局變量與在window對(duì)象上直接定義屬性的區(qū)別說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • JS簡(jiǎn)單實(shí)現(xiàn)移動(dòng)端日歷功能示例

    JS簡(jiǎn)單實(shí)現(xiàn)移動(dòng)端日歷功能示例

    這篇文章主要介紹了JS簡(jiǎn)單實(shí)現(xiàn)移動(dòng)端日歷功能的方法,涉及javascript針對(duì)日期與時(shí)間的操作及顯示相關(guān)技巧,需要的朋友可以參考下
    2016-12-12
  • 分別用marquee和div+js實(shí)現(xiàn)首尾相連循環(huán)滾動(dòng)效果,僅3行代碼

    分別用marquee和div+js實(shí)現(xiàn)首尾相連循環(huán)滾動(dòng)效果,僅3行代碼

    這是本人2007年進(jìn)行的一項(xiàng)研究,當(dāng)時(shí)網(wǎng)絡(luò)上沒(méi)有什么既精簡(jiǎn)又實(shí)用的循環(huán)滾動(dòng)代碼,所以就自己琢磨了段時(shí)間,最終找到這個(gè)辦法
    2011-09-09
  • JavaScript常用數(shù)組去重實(shí)戰(zhàn)源碼

    JavaScript常用數(shù)組去重實(shí)戰(zhàn)源碼

    本文給大家分享js常用8種數(shù)組去重實(shí)戰(zhàn)源碼,針對(duì)每種方法通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧
    2021-07-07
  • JavaScript繼承與多繼承實(shí)例分析

    JavaScript繼承與多繼承實(shí)例分析

    這篇文章主要介紹了JavaScript繼承與多繼承,結(jié)合實(shí)例形式較為詳細(xì)的分析了JavaScript繼承與多繼承的概念、原理、實(shí)現(xiàn)與使用方法,需要的朋友可以參考下
    2018-05-05
  • JavaScript數(shù)組之展開(kāi)運(yùn)算符詳解

    JavaScript數(shù)組之展開(kāi)運(yùn)算符詳解

    這篇文章主要給大家介紹了關(guān)于JavaScript數(shù)組之展開(kāi)運(yùn)算符的相關(guān)資料,你可以通過(guò)展開(kāi)操作符(Spread operator)擴(kuò)展一個(gè)數(shù)組對(duì)象和字符串,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-12-12
  • JavaScript使用canvas實(shí)現(xiàn)flappy bird全流程詳解

    JavaScript使用canvas實(shí)現(xiàn)flappy bird全流程詳解

    這篇文章主要介紹了JavaScript使用canvas實(shí)現(xiàn)flappy bird流程,canvas是HTML5提供的一種新標(biāo)簽,它可以支持JavaScript在上面繪畫(huà),控制每一個(gè)像素,它經(jīng)常被用來(lái)制作小游戲,接下來(lái)我將用它來(lái)模仿制作一款叫flappy bird的小游戲
    2023-03-03
  • IE8 瀏覽器Cookie的處理

    IE8 瀏覽器Cookie的處理

    最近在修改重寫(xiě)自己的簡(jiǎn)歷程序,其中要使用皮膚切換和lightbox效果,在開(kāi)發(fā)的工作中IE8,給我?guī)?lái)點(diǎn)麻煩。
    2009-01-01
  • JS實(shí)現(xiàn)可調(diào)整倒計(jì)時(shí)間代碼分享

    JS實(shí)現(xiàn)可調(diào)整倒計(jì)時(shí)間代碼分享

    這篇文章主要介紹了JS實(shí)現(xiàn)可調(diào)整倒計(jì)時(shí)間代碼,效果很酷炫,也很具有實(shí)用價(jià)值,感興趣的小伙伴們可以參考一下
    2015-08-08

最新評(píng)論