【问题标题】:jQuery parsing XML: get an element with a specific attributejQuery解析XML:获取具有特定属性的元素
【发布时间】:2012-03-03 04:21:15
【问题描述】:

我正在开发一个 HTML5 应用程序。

我想解析这样的 XML:

<?xml version="1.0" encoding="utf-8" ?>
    <cards>
        ...
        <card id="3">
          <name lang="es"></name>
          <description lang="es"></description>
          <name lang="en"></name>
          <description lang="en"></description>
        </card>
        ...
    </cards>

我想获取具有属性 lang="en" 的名称和描述。

我开始写代码,但我不知道如何完成它:

function loadCards(lang)
{
    $.ajax({
        type: "GET",
        url: 'data/english.xml',
        dataType: "xml",
        success:parseCardsXml
    });
}

function parseCardsXml(xml)
{
    $(xml).find('Card').each(function()
    {
        var id = $(this).attr('id');
        var name = $(this).find('name');
    }
}

顺便说一句,loadCards 函数有一个名为 lang 的参数(或参数)。

如何将此参数传递给function parserCardsXml(xml)? 如何获取具有特定属性的名称和描述?

【问题讨论】:

标签: javascript jquery xml xml-parsing


【解决方案1】:

要回答具体问题,“如何将此参数传递给函数 parserCardsXml(xml)?”

function loadCards(lang)
{
    $.ajax({
        type: "GET",
        url: 'data/english.xml',
        dataType: "xml",
        success: function (xml) { parseCardsXml(xml, lang); }
    });
}

还有,“我怎样才能获得具有特定属性的名称和描述?”

function parseCardsXml(xml, lang)
{
    var $xml = $(xml),
        name = $xml.find('name[lang="' + lang + '"]').text(),
        desc = $xml.find('desc[lang="' + lang + '"]').text();
}

【讨论】:

    【解决方案2】:
    var xml='<cards>\
            <card id="3">\
              <name lang="es"></name>\
              <description lang="es"></description>\
              <name lang="en"></name>\
              <description lang="en"></description>\
            </card></cards>';
    

    和 jquery 部分

    $(xml).find('Card').each(function(i,j)
        {           
           console.log($(j).attr("id"));
           console.log($(j).find("name").attr("lang"));
    
        });
    

    http://www.jsfiddle.net/VZjmV/6/

    【讨论】:

      【解决方案3】:

      $(xml).find('name[lang="en"], description[lang="en"]') 应该可以解决问题

      编辑:更完整的答案

      $(xml).find('card').each(function () {
        var id, name, description;
        id          = $(this).attr('id'); // or just `this.id`
        name        = $(this).children('name[lang="en"]').text();
        description = $(this).children('description[lang="en"]').text();
        // do something with the id, name, and description
      });
      

      【讨论】:

      • 感谢您的回答,但是,如何使用找到的值设置 var name 和 var description?
      • @VansFannel 更新了我的答案
      猜你喜欢
      • 1970-01-01
      • 2012-01-16
      • 2015-05-20
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2012-04-14
      • 2021-05-24
      • 1970-01-01
      相关资源
      最近更新 更多