【问题标题】:XML to HTML: Stop loop after a certain number of rowsXML到HTML:一定数量的行后停止循环
【发布时间】:2013-04-19 19:53:15
【问题描述】:

我有一个关于 XML 到 HTML 循环的快速问题。我按照w3schools guideline 从 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>

非常感谢您的帮助!

【问题讨论】:

    标签: html xml xml-parsing


    【解决方案1】:

    Break statement

    for 循环计算并写入从 0 (i=0) 到 XML 行数 (x.length) 的行...只要让它从 0 运行到 9 .. 然后你就得到了 10 行 你可以通过两种方式做到这一点:

    第一个: 替换

    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>
    

    【讨论】:

    • 亲爱的,谢谢!这似乎已经做到了完美!
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2021-08-27
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2017-05-10
    • 2021-09-15
    相关资源
    最近更新 更多