DOM學(xué)習(xí)——Node類型

childNodes

1.節(jié)點獲取

獲取子節(jié)點:某個節(jié)點.childNodes[序號] / 某個節(jié)點.childNodes.item(序號);
序號從零開始
(* ̄(oo) ̄)注:節(jié)點包括文本節(jié)點和元素節(jié)點8爿骸焦辅!

eg: 

      <div>
            <ul id="aa">
                <li><a href="#">1</a></li>
                <li><a href="#">2</a></li>
                <li><a href="#">3</a></li>
            </ul>
            <span>
                aa
            </span>
        </div>
        <script>
            var ul1 = document.getElementById("aa");
            var firstNode = ul1.childNodes[0];
            var firstNode2 = ul1.childNodes.item(0);
            alert(firstNode.nodeName);
            alert(firstNode2.nodeName);
        </script>

節(jié)點的關(guān)系:nextSibling / previousSibling
如果一個父節(jié)點只有一個子節(jié)點紧阔,那么,父節(jié)點的firstChild和lastChild都是這個子節(jié)點娩脾,這個子節(jié)點的 nextSibling / previousSibling 的值都是null;

2.節(jié)點增刪改

增:前提是新建

appendChild()打毛,添加到childNodes列表的最后面

eg:
        <div>
            <ul id="aa">
                <li><a href="#">1</a></li>
                <li><a href="#">2</a></li>
                <li><a href="#">3</a></li>
            </ul>
        </div>
        <script>
            var ul2 = document.getElementById("aa");
            var newChild = document.createElement("li");
            var txt = document.createTextNode("我是新的");
            newChild.appendChild(txt);
            ul2.appendChild(newChild);
        </script>
<!--這里是線創(chuàng)建一個li元素節(jié)點柿赊,然后新建一個文本節(jié)點,把文本節(jié)點添加到元素節(jié)點里面幻枉,
(在一個元素節(jié)點里面有文本節(jié)點闹瞧,那么該文本節(jié)點就是這個元素節(jié)點的子節(jié)點),
再把整個節(jié)點添加到ul的展辞、childNodes列表的最后面-->

插入:insertBefore

在前面插入

eg:
<div>
            <ul id="aa">
                <li><a href="#">1</a></li>
                <li><a href="#">2</a></li>
                <li><a href="#">3</a></li>
            </ul>
        </div>
        <script>
            var ul2 = document.getElementById("aa");
            var newChild = document.createElement("li");
            var txt = document.createTextNode("我是插入的");
            newChild.appendChild(txt);
            
            var li2 = ul2.childNodes[1];
            ul2.insertBefore(newChild,li2);
        </script>

在后面插入
(* ̄(oo) ̄)DOM并沒有提供insertAfter方法奥邮。。罗珍。
要實現(xiàn)的就自己造一個

<div>
            <ul id="aa">
                <li><a href="#">1</a></li>
                <li id="bb"><a href="#">2</a></li>
                <li><a href="#">3</a></li>
            </ul>
        </div>
<script>
var newChild = document.createElement("li");
            var txt = document.createTextNode("我是插入的");
            newChild.appendChild(txt);
            
            var target = document.getElementById("bb");
            function insetAfter(newChild,target){
                var parent = target.parentNode;
                if(target == parent.lastChild){
                    parent.appendChild(newChild);
                }
                else{
                    parent.insertBefore(newChild,target.nextSibling);
                }
                
            }
            insetAfter(newChild,target);
            
        </script>

替換:replaceChild()

<div>
            <ul id="aa">
                <li><a href="#">1</a></li>
                <li id="bb"><a href="#">2</a></li>
                <li><a href="#">3</a></li>
            </ul>
        </div>
<script>
var ul2 = document.getElementById("aa");
            var newChild = document.createElement("li");
            var txt = document.createTextNode("我是替換的");
            newChild.appendChild(txt);
            
            var target = document.getElementById("bb");
            ul2.replaceChild(newChild,target);
            
        </script>

移除:removeChild()

//移除
<div>
           <ul id="aa">
               <li><a href="#">1</a></li>
               <li id="bb"><a href="#">2</a></li>
               <li><a href="#">3</a></li>
           </ul>
       </div>
<script>
           var ul2 = document.getElementById("aa");

           var target = document.getElementById("bb");
           ul2.removeChild(target);
       </script>
//因為replaceChild洽腺、removeChild的節(jié)點都是包含文本節(jié)點的,所以在使用firstChild和lastChild的時候要注意覆旱,當(dāng)前節(jié)點是否為文本節(jié)點蘸朋。

比如下面就會看起來沒有變化
<div>
           <ul id="aa">
               <li><a href="#">1</a></li>
               <li id="bb"><a href="#">2</a></li>
               <li><a href="#">3</a></li>
           </ul>
       </div>
<script>
           var ul2 = document.getElementById("aa");

           var target = document.getElementById("bb");
           ul2.removeChild(ul2.firstChild);
       </script>
上面這幾種方法都是在操作某個節(jié)點的子節(jié)點,所以在使用這些方法之前必須獲取父節(jié)點扣唱,并且藕坯,并不是所有節(jié)點都有子節(jié)點团南,如果在不支持子節(jié)點的節(jié)點使用這些方法,就會導(dǎo)致錯誤的發(fā)生炼彪。

·

克峦赂:cloneNode()

<div>
            <ul id="aa">
                <li><a href="#">1</a></li>
                <li id="bb"><a href="#">2</a></li>
                <li><a href="#">3</a></li>
            </ul>
        </div>
<script>
var ul2 = document.getElementById("aa");
            var newclone = ul2.cloneNode(true);
            var newclone2 = ul2.cloneNode(false);
            document.body.appendChild(newclone);
            document.body.appendChild(newclone2);
</script>
//參數(shù)true:復(fù)制節(jié)點以及整個子節(jié)點樹
//參數(shù)為false:只復(fù)制節(jié)點,不會復(fù)制子節(jié)點
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末辐马,一起剝皮案震驚了整個濱河市拷橘,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌喜爷,老刑警劉巖冗疮,帶你破解...
    沈念sama閱讀 221,406評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異檩帐,居然都是意外死亡术幔,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,395評論 3 398
  • 文/潘曉璐 我一進(jìn)店門湃密,熙熙樓的掌柜王于貴愁眉苦臉地迎上來诅挑,“玉大人,你說我怎么就攤上這事勾缭∽嵴希” “怎么了?”我有些...
    開封第一講書人閱讀 167,815評論 0 360
  • 文/不壞的土叔 我叫張陵俩由,是天一觀的道長毒嫡。 經(jīng)常有香客問我,道長幻梯,這世上最難降的妖魔是什么兜畸? 我笑而不...
    開封第一講書人閱讀 59,537評論 1 296
  • 正文 為了忘掉前任,我火速辦了婚禮碘梢,結(jié)果婚禮上咬摇,老公的妹妹穿的比我還像新娘。我一直安慰自己煞躬,他們只是感情好肛鹏,可當(dāng)我...
    茶點故事閱讀 68,536評論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著恩沛,像睡著了一般在扰。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上雷客,一...
    開封第一講書人閱讀 52,184評論 1 308
  • 那天芒珠,我揣著相機(jī)與錄音,去河邊找鬼搅裙。 笑死皱卓,一個胖子當(dāng)著我的面吹牛裹芝,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播娜汁,決...
    沈念sama閱讀 40,776評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼嫂易,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了存炮?” 一聲冷哼從身側(cè)響起炬搭,我...
    開封第一講書人閱讀 39,668評論 0 276
  • 序言:老撾萬榮一對情侶失蹤蜈漓,失蹤者是張志新(化名)和其女友劉穎穆桂,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體融虽,經(jīng)...
    沈念sama閱讀 46,212評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡享完,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,299評論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了有额。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片般又。...
    茶點故事閱讀 40,438評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖巍佑,靈堂內(nèi)的尸體忽然破棺而出茴迁,到底是詐尸還是另有隱情,我是刑警寧澤萤衰,帶...
    沈念sama閱讀 36,128評論 5 349
  • 正文 年R本政府宣布堕义,位于F島的核電站,受9級特大地震影響脆栋,放射性物質(zhì)發(fā)生泄漏倦卖。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,807評論 3 333
  • 文/蒙蒙 一椿争、第九天 我趴在偏房一處隱蔽的房頂上張望怕膛。 院中可真熱鬧,春花似錦秦踪、人聲如沸褐捻。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,279評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽柠逞。三九已至,卻和暖如春希坚,著一層夾襖步出監(jiān)牢的瞬間边苹,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,395評論 1 272
  • 我被黑心中介騙來泰國打工裁僧, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留个束,地道東北人慕购。 一個月前我還...
    沈念sama閱讀 48,827評論 3 376
  • 正文 我出身青樓,卻偏偏與公主長得像茬底,于是被迫代替她去往敵國和親沪悲。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,446評論 2 359

推薦閱讀更多精彩內(nèi)容