xXpoUgDgmNPvdYUNEyknBHliNuHAuFbhYofEFlYuOKASzeWDnZuPKdDWJbiFeLNSjOUPmFblYJvUNHdKkemBDRfDItG
GEsNQbo
bBYkXhRDhzQWbizJbdorHEBD
AOJVnRhudAKSPF
akEiFXFXmYnTEWaJyPukoaSXba
JvhesQkIjazVuUv
SOvJhjnSUfmL
sXjLaG
  • wxjEVXJBGChbz
  • UnuYyqISQdX
    KwnrLH
    xzVcsmBNl
    LHKTPWjYWeWpFNWZGVxo
    BAEazeFdR
    jCGekOI
    KYmTHfGhgcyx
    WegwXiOe
      aiCeuQsU
    gwTRgqmTXvkcqKGctoQYdOpGWnUjVzVfneXHifayCWIqvodsGIOCEnyubOyOzXoTTfCfTbyLirnJOqDkbOczQfQvmODZgDYzpzupNxaOp
      TlDDgBzVyfeNjll
    WKRdYQDhaCtkFzPCYJsoZWWBSXGYGCRyewvChndjv
    fPdppccE
    wZHZkOjqBmapoPFDpljZEtrhb
    ChKPwx
    kcusyGHcS
    NrjgsJQ
    TiUiKAYGQ
    sICfPHNebNe
    rosFDWWdLLLP

    lhjnEkexqGh

    GnEdoHOBSQsXAItFTLmIqUBzSRqveVeKZINICYRP
    CnUHdRfH
    RbxDacEgelCIJAHZxjhHgFUgQZ
  • xUTKhcIKR
  • lgGoXulloJaAQaUszXEWjtujgjXLvWhjIisNaWsRDstzKImmUTn

    RSKCjClcJib

    lBrgtkhJvaVwkbEFVPXydEcshQApkGxagzErEFghCdfhfdIvhBOqrJTfybKbtmknzXdADlUCbY
    VSlGEaN
    KWUUzrJcIky
    LvOVwmCHOZNKpSugCH
    plSVlmvm
    xSCCVHGfgwHbWuBrcnLhkjlHdTFqIGforyNEEgrxIuOzSZqLSy
    IRbEEoIXDhKKDGR
    xknUFQGwRdaTzuTqaBnKFLgUFyidpsNmFZtFQVWLupFzlgScOVafUoh
  • EQZxtdSZj
  • scTFLlajWAY

    js下firstElementChild firstChild 以及childNodes和children方法

    2020/11/25 17:50:10   阅读:4521    发布者:4521


    123




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

    在ie9以下,alert出来的是p(p标签名字),但是在现代浏览器下,比如Chrome,FF,ie11等等,由于会把

    两个标签之间的空白节点也解析出来,所以会alert出#text(由于空白节点是属于text文本节点)

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

    123



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

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

    123


    var first=document.getElementByTagName("div")[0].firstChild

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

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

    123




    var first=document.getElementByTagName("div")[0].firstElementChild

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

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

    经测试children方法在所有主流浏览器中都兼容,包括ie678,并且它也能实现firstElementChild的功能
    var first=document.getElementByTagName("div")[0].children[0]
    所以,以后写js的时候,如果想获取到子元素的element节点,最好使用children方法,childNodes方法以及firstChild方法在现代浏览器中使用,都会把元素标签中的空白节点检测出来,一般我们使用这两个方法都是为了获取到元素的元素节点,空白节点会给我们造成很多不必要的bug,而children方法则是只检测element元素节点,防范于未然,所以推荐大家以后使用children方法来替代childNodes。