简单东西-jQuery解析xml数据

      CSDN的ask频道看到一个问题,使用jQuery的ajax请求返回xml格式的数据,并对其进行解析。但是我测试了提问者的代码,结果是解析xml的find方法没有查到结果。查看了jQuery的find的API,其实这是个很简单的API运用问题,理解了find的用法,就很容易明白错误所在了。find() 方法获得当前元素集合中每个元素的后代,通过选择器、jQuery 对象或元素来筛选。

    问题代码:

var xml = '<yweather:location city="Beijing" region="" country="CH"/>';
$(xml).find("yweather:location").each(function(){
     $("#show2").text(
     $(this).attr("city")
     );
 });

      正确的是:

<!DOCTYPE html>
<html>
<head>
<script src="/jquery/jquery-1.11.1.min.js"></script>
<script>
$(document).ready(function(){
  var xml = '<t><yweather:location city="Beijing" region="" country="CH"/></t>';
  var list = $(xml).find("yweather\\:location ");
  alert("list length:"+list.length+","+$(list[0]).attr("city"));
});
</script>
</head>
<body>
</body>
</html>
     find查询的是当前元素的子节点,如果当前元素没有子节点,显然find是不会有结果的;此外find的节点如果含义特殊字符冒号:,那么如果不转义的话,jQuery就会当作选择器来处理了,所以即使有子节点也是查无所获的。所以查询yweather:location这个节点时需要对冒号进行转义。

你可能感兴趣的:(jquery,find)