jquery - 使用 Jquery 查找 XML 元素值

标签 jquery xml ajax

我有一个 XML 文件,我需要使用 Jquery 和 Ajax 找到特定 PK 的项目 到目前为止,我了解了这个对象,但我有两个问题:

  1. 有没有比循环查找 pk 值更好的主意?
  2. XML 很大,我需要知道是否有比将其加载到内存中更好的查询方式,XSLT 是否有更好的帮助?还是有比 jquery 更好的方法?

这是我的代码

$.ajax({
    url: 'xml/products.xml',
    dataType: 'html',
    success: function(xml) {
        $(xml).find('pk').each(function() {
            if ($(this).text() == "1")
            //do something
        });
    }
});

这是我的xml

<products>
<item>
    <pk>1</pk>
    <name>test</name>
</item>
<item>
    <pk>2</pk>
    <name>test2</name>
</item>
<item>
    <pk>3</pk>
    <name>test3</name>
</item>
<item>
    <pk>4</pk>
    <name>test4</name>
</item>
</products>

最佳答案

首先,您必须编写正确的 XML 字符串,就像您必须完成/结束上一个开始的相同标签一样。在上面的示例代码中,您在关闭时犯了错误。这是错误的 xml 语法。请更正如下: 1个 测试

这里我制作了用于解析 XML 数据或标签的样本箱,而不是 Ajax 我只是在按钮单击事件上解析 xml 数据,因为在箱子上 Ajax 调用不可能调用外部文件。

这是演示:http://codebins.com/bin/4ldqp7u

HTML

<div>
  <input type="button" id="btnxml" value="Get XML Data" />
  <input type="button" id="btnreset" value="Reset" style="display:inline"/>
  <div id="result">
  </div>
</div>
<div id="xmldata">
  <products>
    <item>
      <pk>
        1
      </pk>
      <name>
        test
      </name>
    </item>
    <item>
      <pk>
        2
      </pk>
      <name>
        test2
      </name>
    </item>
    <item>
      <pk>
        3
      </pk>
      <name>
        test3
      </name>
    </item>
    <item>
      <pk>
        4
      </pk>
      <name>
        test4
      </name>
    </item>
  </products>
</div>

JQuery:

$(function() {
    $("#btnxml").click(function() {
        var xml = "<rss version='2.0'>";
        xml += $("#xmldata").html();
        xml += "</rss>";
        var xmlDoc = $.parseXML(xml),
            $xml = $(xmlDoc);

        var result = "";
        if ($xml.find("item").length > 0) {

            result = "<table class='items'>";
            result += "<tr><th>PK</th><th>Name</th></tr>";

            $xml.find("item").each(function() {
                result += "<tr>";
                result += "<td>" + $(this).find("pk").text() + "</td>";
                result += "<td>" + $(this).find("name").text() + "</td>";
                result += "</tr>";
            });

            result += "</table>";
            $("#result").html(result);
        }


    });

    //Reset Result 
    $("#btnreset").click(function() {
        $("#result").html("");
    });

});

CSS:

#xmldata{
  display:none;
}
table.items{
  margin-top:5px;
  border:1px solid #6655a8;
  background:#55a5d9;
  width:20%;
}
table.items th{
  border-bottom:1px solid #6655a8;
}
table.items td{
  text-align:center;
}
input[type=button]{
  border:1px solid #a588d9;
  background:#b788d9;
}

演示: http://codebins.com/bin/4ldqp7u

关于jquery - 使用 Jquery 查找 XML 元素值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12256547/

相关文章:

javascript - 如何在 PHP 中执行基于事件的操作

jQuery - 当在带有空字段的表单上单击按钮时,背景颜色和文本淡入

ruby-on-rails - :remote => true not working when a file uploader is used in form

php - Javascript 变量 - 未定义

java - 我可以从类似于 jaxb 的 json 数据创建类吗

java - undefined variable 上的 BaseX XQJ API 错误,而变量已定义

xml - 在 Yii 中显示 XML 文档

jquery - 使用 jquery 和框的单击事件自动填充国家/地区名称列表框

javascript - 仅 Chrome : ajax freezing my javascript execution

javascript - 图像选择器在初始化时预选项目