DOM节点关系(一)

节点中的各种关系可以用传统的家族关系来描述,相当于把文档树比喻成家谱。

父节点

parentNode获取该节点的父节点

window.onload=function(){

var oInput=document.getElementsByTagName("input");

for (var i=0;i

oInput[i].onclick=function(){

this.parentNode.style.display="none";

}

}

}

我的爱好

  • 爬山
  • 跑步
  • 读书
  • 运行结果:

    点击每一行对应的隐藏按钮,对应的爱好就会隐藏。

    子节点

    childNodes

    获取该节点的子节点数组

    window.onload=function(){

    var oUl=document.getElementById("ul1");

    console.log(oUl.childNodes.length);//7

    console.log(oUl.childNodes[0].nodeType);

    console.log(oUl.childNodes[1].nodeType);

    for (var i=0;i

    if (oUl.childNodes[i].nodeType==1){

    // oUl.childNodes[i].style.background="red";

    }

    }

    // oUl.firstChild.style.background="red";

    // oUl.firstElementChild.style.background="red";

    var oFirst=oUl.firstElementChild||oUl.firstChild;

    oFirst.style.background="red";

    }

    • 111
    • 222
    • 333
    • 运行结果:7

      这是在谷歌浏览器运行的结果,因为在ul后面的空白节点作为它的子节点,在火狐以及其他非IE浏览器也是这样的,只有在IE浏览器ul的子节点的个数为3。当把ul、li的空白都消除后,那么ul的子节点的长度就为3,如下所示

      • 111
      • 222
      • 333

      这就是为什么在非IE浏览器中ul的子节点个数为7而不是3的原因,也就是说

      childNodes存在浏览器兼容的问题。

      childNodes要结合nodeType(节点类型)一起使用。

      nodeType :节点类型,返回值为数字

      元素:1

      属性:2

      文本:3

      注释:8

      文档:9

      for (var i=0;i

      if (oUl.childNodes[i].nodeType==1){

      oUl.childNodes[i].style.background="red";

      }

      }

      该代码可以设置ul子节点的背景颜色为红色

      firstChild

      获取该节点的第一个子节点

      只有在IE浏览器表示第一个子节点

      firstElementChild

      获取该节点的第一个子节点。在非IE浏览器中表示第一个子节点

      为例解决第一个子节点的浏览器兼容问题,我们需要用到或(||)操作符

      var oFirst=oUl.firstElementChild||oUl.firstChild;

      oFirst.style.background="red";

      该代码可以设置ul第一个子节点111的背景颜色为红色

      lastChild

      获取该节点的最后一个子节点

      lastElementChild

      获取该节点的最后一个子节点

      最后一个子节点和第一个子节点一样存在兼容问题,也是以同样的方式解决

      最后编辑于
      ©著作权归作者所有,转载或内容合作请联系作者
      • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
        沈念sama阅读 217,277评论 6 503
      • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
        沈念sama阅读 92,689评论 3 393
      • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
        开封第一讲书人阅读 163,624评论 0 353
      • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
        开封第一讲书人阅读 58,356评论 1 293
      • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
        茶点故事阅读 67,402评论 6 392
      • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
        开封第一讲书人阅读 51,292评论 1 301
      • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
        沈念sama阅读 40,135评论 3 418
      • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
        开封第一讲书人阅读 38,992评论 0 275
      • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
        沈念sama阅读 45,429评论 1 314
      • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
        茶点故事阅读 37,636评论 3 334
      • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
        茶点故事阅读 39,785评论 1 348
      • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
        沈念sama阅读 35,492评论 5 345
      • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
        茶点故事阅读 41,092评论 3 328
      • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
        开封第一讲书人阅读 31,723评论 0 22
      • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
        开封第一讲书人阅读 32,858评论 1 269
      • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
        沈念sama阅读 47,891评论 2 370
      • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
        茶点故事阅读 44,713评论 2 354

      推荐阅读更多精彩内容