如何从AJAX的responseText中提取数据?

时间:2012-02-03 22:02:03

标签: javascript ajax responsetext

当我使用responseText时,我获得了所有数据。从<HTML></HTML>。如何提取它的具体部分?例如,我有这段代码:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
        <title>Tester</title>
    </head>

    <body>

        <table>
            <tr>
                <td><a name="Name"></a>Name</td>
                <td>John</td>
            </tr>
            <tr>
                <td><a name="Email"></a>Email</td>
                <td>john@aol.com</td>
            </tr>
            <tr>
                <td><a name="Address"></a>Address</td>
                <td>123 Elm Street</td>
            </tr>
            <tr>
                <td><a name="City"></a>City</td>
                <td>Los Angeles</td>
            </tr>
            <tr>
                <td><a name="State"></a>State</td>
                <td>CA</td>
            </tr>
        </table>

    </body>
</html>

然后我需要提取像城市部分洛杉矶。我该怎么做呢?我不能做responseText.getElementByTagName,或类似的东西。

这是AJAX电话:

var xmlhttp;
if (window.XMLHttpRequest)
  {// code for IE7+, Firefox, Chrome, Opera, Safari
  xmlhttp=new XMLHttpRequest();
  }
else
  {// code for IE6, IE5
  xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
  }
xmlhttp.onreadystatechange=function()
  {
  if (xmlhttp.readyState==4 && xmlhttp.status==200)
    {
    var pageContents = xmlhttp.responseText;
    document.getElementById("myDiv").innerText = pageContents;

    }
  }
xmlhttp.open("GET","content.html",false);
xmlhttp.send();

2 个答案:

答案 0 :(得分:1)

对于纯JavaScript解决方案,请尝试(未经测试):

var city = responseXML.getElementsByName('City').parentNode.nextElementSibling.childNodes[0].getAttribute('textContent');

也就是说,像jQuery这样的JavaScript库可以确保您的代码更容易阅读(以及跨浏览器友好)。

答案 1 :(得分:0)

jQuery简单地命名这个(有点):

alert($('table').find('tr').eq(3).find('td').eq(1).html()) ---&gt;洛杉矶