搞懂children和childNodes

children(HTMLCollection)

children返回的是一個元素的子元素觅玻,只包括元素節(jié)點(diǎn)想际,不包含文本節(jié)點(diǎn)、注釋節(jié)點(diǎn)

    <script>
    window.onload = function(){
        var oUl = document.getElementsByTagName('ul')[0];
        console.log(oUl.children.length) // 2
    }
    </script>
    <body>
        <ul> i am text node
            <li></li> i am text node too
            <li></li><!--this is note-->
        </ul>
    </body>

childNodes (Nodelist)

childNodes返回的是所有子節(jié)點(diǎn)的一個集合溪厘,包括元素節(jié)點(diǎn)胡本、文本節(jié)點(diǎn)、注釋節(jié)點(diǎn)(如果一段文本被一個注釋所分開畸悬,那么這里就有三個節(jié)點(diǎn):文本節(jié)點(diǎn)侧甫、注釋節(jié)點(diǎn)、文本節(jié)點(diǎn))

    <script>
    window.onload = function(){
        var oUl = document.getElementsByTagName('ul')[0];
        console.log(oUl.childNodes.length) // 2
    }
    </script>
    <body>
        <ul> i am text node
            <li></li> i am text node too
            <li></li><!--this is note-->
        </ul>
    </body>

補(bǔ)充

關(guān)于nodeType:

元素節(jié)點(diǎn):nodeType === 1
屬性節(jié)點(diǎn):nodeType === 2
文本節(jié)點(diǎn):nodeType === 3
注釋節(jié)點(diǎn):nodeType === 8
文檔節(jié)點(diǎn)(document):nodeType === 9

關(guān)于HTMLCollection和NodeList:

主要區(qū)別是蹋宦,NodeList可以包含各種類型的節(jié)點(diǎn)披粟,HTMLCollection只能包含 HTML 元素節(jié)點(diǎn)。

NodeList

NodeList的成員可以是任意類型的節(jié)點(diǎn)

NodeList可以是動態(tài)的(element.childNodes)也可以是靜態(tài)的(document.querySeletorAll())

所謂動態(tài)指的是這個集合是動態(tài)的,如果動態(tài)添加子元素,那么這個集合也會發(fā)生變化

NodeList有l(wèi)ength列疗,forEach方法岂昭,keys(),values()等背桐,是一個類數(shù)組

HTMLCollection

HTMLCollection是一個節(jié)點(diǎn)對象的集合,只能包含元素節(jié)點(diǎn)(element),不能包含其他類型的節(jié)點(diǎn)碰镜。它的返回值是一個類似數(shù)組的對象,但是與NodeList接口不同习瑰,HTMLCollection沒有forEach方法绪颖,只能使用for循環(huán)遍歷。

返回HTMLCollection實(shí)例的甜奄,主要是一些Document對象的集合屬性柠横,比如document.links、document.forms课兄、document.images等牍氛。

以及document.getElementsByTagName(),document.getElementsByClassName(),element.children()等

HTMLCollection實(shí)例都是動態(tài)集合,節(jié)點(diǎn)的變化會實(shí)時反映在集合中

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末烟阐,一起剝皮案震驚了整個濱河市搬俊,隨后出現(xiàn)的幾起案子紊扬,更是在濱河造成了極大的恐慌,老刑警劉巖唉擂,帶你破解...
    沈念sama閱讀 207,248評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件餐屎,死亡現(xiàn)場離奇詭異,居然都是意外死亡玩祟,警方通過查閱死者的電腦和手機(jī)腹缩,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,681評論 2 381
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來空扎,“玉大人藏鹊,你說我怎么就攤上這事∽猓” “怎么了盘寡?”我有些...
    開封第一講書人閱讀 153,443評論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長撮慨。 經(jīng)常有香客問我宴抚,道長,這世上最難降的妖魔是什么甫煞? 我笑而不...
    開封第一講書人閱讀 55,475評論 1 279
  • 正文 為了忘掉前任菇曲,我火速辦了婚禮,結(jié)果婚禮上抚吠,老公的妹妹穿的比我還像新娘常潮。我一直安慰自己,他們只是感情好楷力,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,458評論 5 374
  • 文/花漫 我一把揭開白布喊式。 她就那樣靜靜地躺著,像睡著了一般萧朝。 火紅的嫁衣襯著肌膚如雪岔留。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,185評論 1 284
  • 那天检柬,我揣著相機(jī)與錄音献联,去河邊找鬼。 笑死何址,一個胖子當(dāng)著我的面吹牛里逆,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播用爪,決...
    沈念sama閱讀 38,451評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼原押,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了偎血?” 一聲冷哼從身側(cè)響起诸衔,我...
    開封第一講書人閱讀 37,112評論 0 261
  • 序言:老撾萬榮一對情侶失蹤盯漂,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后笨农,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體宠能,經(jīng)...
    沈念sama閱讀 43,609評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,083評論 2 325
  • 正文 我和宋清朗相戀三年磁餐,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片阿弃。...
    茶點(diǎn)故事閱讀 38,163評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡诊霹,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出渣淳,到底是詐尸還是另有隱情脾还,我是刑警寧澤,帶...
    沈念sama閱讀 33,803評論 4 323
  • 正文 年R本政府宣布入愧,位于F島的核電站鄙漏,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏棺蛛。R本人自食惡果不足惜怔蚌,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,357評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望旁赊。 院中可真熱鬧桦踊,春花似錦、人聲如沸终畅。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,357評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽离福。三九已至杖狼,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間妖爷,已是汗流浹背蝶涩。 一陣腳步聲響...
    開封第一講書人閱讀 31,590評論 1 261
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留絮识,地道東北人子寓。 一個月前我還...
    沈念sama閱讀 45,636評論 2 355
  • 正文 我出身青樓,卻偏偏與公主長得像笋除,于是被迫代替她去往敵國和親斜友。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,925評論 2 344

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