javascript - 如何调用xml信息
黄舟
黄舟 2017-04-11 11:48:50
0
4
244

我的xml文件如下:

   日期 build号 通过率   日期 build号 通过率   日期 build号 通过率   日期 build号 通过率   日期 build号 通过率  

我想日期在一行,build号在一行,通过率在一行,这样对应着形成表格。

日期 日期 日期 日期
build build build build
rate rate rate rate

而我这样写

直接变成

我只会一行行来写,但是那样我的xml格式就要变动。
请问我要不变xml格式怎样生成合适的表格?

黄舟
黄舟

人生最曼妙的风景,竟是内心的淡定与从容!

Antworte allen (4)
小葫芦

我的做法可能会更慢一些,因为中间转换了数据,但是应该更好理解。

https://jsfiddle.net/kvoedtjb/

// 用这个来模拟 ajax 得到的 xml const xml = $(xml); // 先从 XML 提取数据,以 JavaScript 对象形式取出来 const data = $("build") .map((i, build) => { const $build = $(build); return { date: $build.children("date").text(), buildnum: $build.children("buildnum").text(), rate: $build.children("rate").text() }; }) .toArray(); // 因为表格显示的样式是转置后的,所以这里按列标题(作为行)来转置 const rotate = ["date", "buildnum", "rate"].map(name => { return data.map(m => m[name]); }); // 生成行 jQuery 对象(包含单元格) const rows = rotate.map(row => { const tds = row.map(v => { return $("").text(v || ""); }); return $("").append(tds); }); // 所有行加入到表格中去 $("table").empty().append(rows);
    左手右手慢动作

    在你代码基础上改的,有一些可以优化的地方

      刘奇

      你这问题真心看不明白。麻烦再说清楚点,愁死我了。

        大家讲道理
        $(document).ready(function(){ $.ajax({ type:"GET", dataType:"xml", url:"1.xml", success:function(xml){ var htmlData=""; var dateTr=""; var buildnumTr=""; var rateTr=""; $(xml).find('build').each(function(index,item){ var $student = $(this); var date = $student.find('date').text(); var buildnum = $student.find('buildnum').text(); var rate = $student.find('rate').text(); dateTr += ""; buildnumTr += ""; rateTr += ""; }); htmlData+=""+dateTr+""+buildnumTr+""+rateTr+"
        "+date+""+buildnum+""+rate+"
        "; $("body").append(htmlData); }, }); }); 这样子应该就可以.
          Neueste Downloads
          Mehr>
          Web-Effekte
          Quellcode der Website
          Website-Materialien
          Frontend-Vorlage
          Über uns Haftungsausschluss Sitemap
          Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!