为了账号安全,请及时绑定邮箱和手机立即绑定

如何找到指定的子节点

<script  type="text/javascript">
    var mylist = document.getElementById("tcon"); 
    var parent=mylist.parentNode.parentNode.parentNode;
    var childList=parent.childNodes;
    for(var i=0;i<childList.length;i++){
        if(childList[i].getAttribute("id")=="lesson4"){
            var sunList=childList[i].childNodes;
            for(var j=0;j<sunList.length;j++){
                document.write(sunList[j].innerHTML+"  ");
            }
         }
       }

这里面那个childList[i].getAttribute("id")=="lesson4"是错误的表达,请问能不能得到指定的子节点呢

正在回答

3 回答

childList[i].getAttribute("id")=="lesson4"表达式正确,但是你需要先排除nodeType 类型是text的,才会执行你下面的代码,否则直接报错

0 回复 有任何疑惑可以回复我~
#1

思进行

为什么把lastChild换成document.write(mylist.parentNode.parentNode.parentNode.firstChild.innerHTML);会输出undefined,不应该是lesson1的内容被输出出来的嘛
2019-02-11 回复 有任何疑惑可以回复我~

这样写只获取到 <li id="lesson4">…</li> 这部分的子节点,分别是 HTML/CSS、<ul>…</ul> 与 空白符(非IE下),还需要一层循环来获取 <ul>…</ul> 子节点中的内容啊!

1 回复 有任何疑惑可以回复我~

<ul id="con">

<li id="lesson1">javascript

  <ul> 

      <li id="tcon"> 基础语法</li>

      <li>流程控制语句</li>

      <li>函数</li>

      <li>事件</li>

      <li>DOM</li>

  </ul>

</li>

<li id="lesson2">das</li>

<li id="lesson3">dadf</li>

<li id="lesson4">HTML/CSS 

  <ul>

    <li>文字</li>

    <li>段落</li>

    <li>表单</li>

    <li>表格</li>  

  </ul> 

</li></ul> 


0 回复 有任何疑惑可以回复我~

举报

0/150
提交
取消

如何找到指定的子节点

我要回答 关注问题
意见反馈 帮助中心 APP下载
官方微信