如何使用Javascript迭代遍历元素的子节点?

3
我正在尝试遍历DOM元素的子元素,并在我的代码中显示它们的属性:
document.write("<table border='1'>");
var testcaseiterator = xmlDoc.getElementsByTagName("TestCase")[1].childNodes;

for(i=0; i < testcaseiterator.length; i++){

    document.write("<tr><td>");
    document.write(testcaseiterator[i].getAttribute('name'));
    document.write("</td></tr>");
}
document.write("</table>");

我的XML:

<?xml version="1.0" encoding="UTF-8"?>
<?xml-stylesheet type="text/xsl" href="XSLTOutput2.xsl"?>
<TestSuite>
  <ActiveStep case="6" step="14" />
  <TestCase name="Visit all buttons [in region Button: Navi 0]">
    <Verification type="screen" id="1e542f75-1ba2-482d-8edd-39f70620d6dd" status="">
      <screen widgetid="audio_radio_fm">
        <menu entryStrategy="FIRST" looped="false" orientation="HORIZONTAL" selectable="true" widgetid="status">
          <entry selectable="true" widgetid="status" widgettype="entry">
            <label widgetid="status_label">status</label>
          </entry>
        </menu>
        <menu entryStrategy="SECOND" looped="false" orientation="HORIZONTAL" selectable="true" widgetid="apl">
          <button selectable="true" widgetid="apl_navi" widgettype="button">
            <label widgetid="apl_navi_label">Navi</label>
          </button>
          <button selectable="true" widgetid="apl_audio" widgettype="button">
            <label widgetid="apl_audio_label">Audio</label>
          </button>
          <button selectable="true" widgetid="apl_tel" widgettype="button">
            <label widgetid="apl_tel_label">Tel</label>
          </button>
          <button selectable="true" widgetid="apl_video" widgettype="button">
            <label widgetid="apl_video_label">Video</label>
          </button>
          <button selectable="true" widgetid="apl_system" widgettype="button">
            <label widgetid="apl_system_label">System</label>
          </button>
          <button selectable="true" widgetid="apl_net" widgettype="button">
            <img src="img/apl_net.png" widgetid="apl_net_image" />
          </button>
        </menu>
        <menu entryStrategy="FIRST" looped="false" orientation="HORIZONTAL" selectable="true" widgetid="plf">
          <entry selectable="true" widgetid="playfield" widgettype="entry">
            <label widgetid="playfield_label">playfield</label>
          </entry>
        </menu>
        <menu entryStrategy="MIDDLE" looped="false" orientation="HORIZONTAL" selectable="true" widgetid="audio_radio_sfl">
          <button selectable="true" widgetid="audio_radio_sfl_radio" widgettype="button">
            <label widgetid="audio_radio_sfl_radio_label">Radio</label>
          </button>
          <button selectable="true" widgetid="audio_radio_sfl_presets" widgettype="button">
            <label widgetid="audio_radio_sfl_presets_label">Presets</label>
          </button>
          <button selectable="true" widgetid="audio_radio_sfl_info" widgettype="button">
            <label widgetid="audio_radio_sfl_info_label">Info</label>
          </button>
          <button selectable="true" widgetid="audio_radio_sfl_fm" widgettype="button">
            <label widgetid="audio_radio_sfl_fm_label">FM</label>
          </button>
          <button selectable="true" widgetid="audio_radio_sfl_sound" widgettype="button">
            <label widgetid="audio_radio_sfl_sound_label">Sound</label>
          </button>
        </menu>
      </screen>
    </Verification>
    <Verification optionID="Audio" type="focus" id="d713b58b-06b1-4274-9a79-fe90a071383c" status="" />
    <Command type="cce:left" id="3a591a3c-9b9f-41a7-9b50-0892197128ec" status="" />
    <Verification optionID="Navi" type="focus" id="6037419a-25ae-4a7f-b842-0e88df9dfe4c" status="" />
  </TestCase>

这个不起作用:有什么想法吗?


1
它为什么不工作?发生了什么事?控制台上有错误吗? - James Montagne
浏览器没有错误。表格只是没有显示出来。如果我在document.write()中只写一个字符串,那么它会打印出几行我的字符串。不过数量不正确。 - Hans En
你的代码中有没有使用过 document.write("<table>") 这段代码? - bfavaretto
1个回答

5
var testcaseiterator = xmlDoc.getElementsById("tc").childNodes;

代码的其余部分看起来没什么问题。
for(i=0; i < testcaseiterator.length; i++)
 {
     document.write("<tr><td>");
     document.write(testcaseiterator[i].getAttribute('name'));
     document.write("</td></tr>");
 }
 document.write("</table>")

您还需要编辑XML的第五行,

 <TestCase id ="tc"  name="Visit all buttons [in region Button: Navi 0]">

这仅在你的DOM结构中包含XML时才有效。

childNodes 对我不起作用,我使用 children 就可以了。 - IgniteCoders
这个 children[i].getAttribute('name') 对我没用,但是这个可以:children[i].tagName - Kresimir Pendic

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接