1

我有一个关于 XML 到 HTML 循环的快速问题。我遵循w3schools 指南从 XML 文档呈现 HTML 表格,一切都很好!我不想更改代码的任何内容,但我想知道是否可以在呈现十行之后停止循环,即使原始 XML 文件包含更多数据。如果是这样,我将如何更改 w3schools 显示的示例中的代码(转载如下)?

<script>
if (window.XMLHttpRequest)
  {// code for IE7+, Firefox, Chrome, Opera, Safari
  xmlhttp=new XMLHttpRequest();
  }
else
  {// code for IE6, IE5
  xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
  }
xmlhttp.open("GET","cd_catalog.xml",false);
xmlhttp.send();
xmlDoc=xmlhttp.responseXML; 

document.write("<table border='1'>");
var x=xmlDoc.getElementsByTagName("CD");
for (i=0;i<x.length;i++)
  { 
  document.write("<tr><td>");
  document.write(x[i].getElementsByTagName("ARTIST")[0].childNodes[0].nodeValue);
  document.write("</td><td>");
  document.write(x[i].getElementsByTagName("TITLE")[0].childNodes[0].nodeValue);
  document.write("</td></tr>");
  }
document.write("</table>");
</script>

非常感谢您的帮助!

4

1 回答 1

1

中断声明

for 循环计算并写入从 0 (i=0) 到 XML 行数 (x.length) 的行...只需让它从 0 运行到 9 .. 然后你得到 10 行你可以通过 2 种方式来完成:

第一种:更换

for (i=0;i<x.length;i++)

for (i=0;i<=9;i++)

第二:

在括号内包含一个 if 语句

    <script>
if (window.XMLHttpRequest)
  {// code for IE7+, Firefox, Chrome, Opera, Safari
  xmlhttp=new XMLHttpRequest();
  }
else
  {// code for IE6, IE5
  xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
  }
xmlhttp.open("GET","cd_catalog.xml",false);
xmlhttp.send();
xmlDoc=xmlhttp.responseXML; 

document.write("<table border='1'>");
var x=xmlDoc.getElementsByTagName("CD");
for (i=0;i<x.length;i++)
  { 
  if(i==10)
     break;
  document.write("<tr><td>");
  document.write(x[i].getElementsByTagName("ARTIST")[0].childNodes[0].nodeValue);
  document.write("</td><td>");
  document.write(x[i].getElementsByTagName("TITLE")[0].childNodes[0].nodeValue);
  document.write("</td></tr>");
  }
document.write("</table>");
</script>
于 2013-04-19T19:55:55.420 回答