如何解析从 url 返回的此 xml

How can I parse this xml returned from a url?

本文关键字:xml 返回 url 何解析      更新时间:2023-09-26

>我的网址有以下xml返回:

<?xml version="1.0"?>
<categories>
  <category>
    <catid>17</catid>
    <name>Collage</name>
    <parent></parent>
  </category>
  <category>
    <catid>15</catid>
    <name>Letter Mats</name>
    <parent></parent>
  </category>
  <category>
    <catid>182</catid>
    <name>Single Opening</name>
    <parent></parent>
  </category>
</categories>

我的JavaScript代码,我有:

var matte_select_options = new Array();
function matte_designs_populate_types()
{
  $(document).ready(function()
  {
    $.ajax({
      type: "GET",
      url: "myurl/system/components/catsxml/3",
      dataType: 'xml',
      success: function(xml) {
        designs = xml.getElementsByTagName("categories")[0].childNodes;
        var output = [];
        alert(designs.length);
        for (i = 0; i < designs.length; i++)
        {
          var catid = designs[i].getAttribute("catid");
          var name = designs[i].getAttribute("name");
          output.push('<option value="'+ catid +'">'+ name +'</option>');
          matte_select_options[catid] = name;
        }
        $('#matte_designs').html(output.join(''));
      }
    });
  });
}

出于某种原因,警报给了我 7,我不确定为什么。不过,主要问题是选择没有填充,因为甚至没有设置 catid 和名称。

您可以将返回的XML转换为jQuery对象,然后像往常一样使用jQuery的DOM遍历函数。试试这个:

success: function(xml) {
    var output = [];
    $('category', xml).each(function(i, el) {
        var catid = $("catid", this).text();
        var name = $("name", this).text();
        output.push($('<option />', { value: catid, text: name }));
        matte_select_options[catid] = name;
    });
    $('#matte_designs').html(output);
}

示例小提琴

在你的xml示例中:catidname不是atrributes。它们是节点,信息包含在它们的内容中。

如果您使用的是 jQuery ,您应该能够使用 jQuery 选择器和操纵器解析 xml:

success: function(xml) {
    var designs = $(xml).find('category');
    var output = [];
    designs.each(function(){
        var catid = $(this).find('catid').text();
        var name = $(this).find('name').text();
        output.push('<option value="'+ catid +'">'+ name +'</option>');
        matte_select_options[catid] = name;
    });
    $('#matte_designs').html(output.join(''));
  }