zoukankan      html  css  js  c++  java
  • js下firstElementChild firstChild 以及childNodes和children方法

    一、

    <div>
        <p>123</p>
    </div>

    在上面这段代码中,如果使用以下js代码

    var oDiv=document.getElementByTagName("div")[0];
    alert(oDiv.firstChild.nodeName)

    在ie9以下,alert出来的是p(p标签名字),但是在现代浏览器下,比如Chrome,FF,ie11等等,由于会把<div>   <p>两个标签之间的空白节点也解析出来,所以会alert出#text(由于空白节点是属于text文本节点)

    如果把html的Demo改成如下,则无论在古老浏览器还是现代浏览器中得到的结果都是一样

    <div><p>123</p></div>

    由于没有了div与p标签之间的空白,所以执行上面js代码时无论在ie678还是现代浏览器中都输出p标签

    二、

    在平时写js中,我们经常会想用一个方法直接获取到父元素的第一个子元素节点,就好比如上面的例子中,使用firstChild确实可以实现这一功能

    <div><p>123</p></div>
    var first=document.getElementByTagName("div")[0].firstChild

    这样我们就可以获取到第一个元素子节点,但是当div与p之间存在空白节点的话,first就会获取到空白节点而不是第一个元素节点。

    所以,DOM扩展了一个firstElementChild方法,这个方法可以获取到父元素的第一个子元素节点

    <div>
        <p>123</p>
    </div>
    var first=document.getElementByTagName("div")[0].firstElementChild

    即便div与p标签中存在空白节点,但是使用firstElementChild方法仍然可以正常的获取到div的第一个子元素节点p。

    但是问题又来了,firstElementChild这个方法在现代浏览器中兼容,但是在ie678中却没有这个方法,一旦在ie678中使用这个方法就会出错

    三、

    虽然firstElementChild方法在ie678中不兼容,但是还有一个方法,便是Children方法。

    经测试children方法在所有主流浏览器中都兼容,包括ie678,并且它也能实现firstElementChild的功能

    <div>
        <p>123</p>
    </div>
    var first=document.getElementByTagName("div")[0].children[0]

    所以,以后写js的时候,如果想获取到子元素的element节点,最好使用children方法,childNodes方法以及firstChild方法在现代浏览器中使用,都会把元素标签中的空白节点检测出来,一般我们使用这两个方法都是为了获取到元素的元素节点,空白节点会给我们造成很多不必要的bug,而children方法则是只检测element元素节点,防范于未然,所以推荐大家以后使用children方法来替代childNodes。

    以上摘自:http://www.cnblogs.com/jelly7723/p/4871849.html

    四、补充:

    同时兼容高低版本的浏览器:

    <ul id="ul1">
        <li><span>dgfgfhgh</span></li>
        <li></li>
        <li></li>
    </ul>
    window.onload=function(){
            oUl1=document.getElementById("ul1");
            if(oUl1.firstElementChild){
                oUl1.firstElementChild.style.background='red';
            }else {
                oUl1.firstChild.style.background='red';
            }
        }
    需注意:firstChild在IE中包含注释节点。
  • 相关阅读:
    模板之导入include
    模板之继承
    jQuery ajax简单用法
    Django 路由系统URL
    Django 的简单使用
    python selenium web自动化的三种等待的区别
    Django的数据库介绍
    Django 安装与介绍
    插件轮播
    bootstrap 简单使用(实现图标和按钮下拉)
  • 原文地址:https://www.cnblogs.com/hjbky/p/6229665.html
Copyright © 2011-2022 走看看