1

我正在使用带有 jquery 的 Last.fm API,如下所示:

$.getJSON('http://ws.audioscrobbler.com/2.0/?JSONCallback=?', {
    method: "user.getweeklytrackchart",
    user: "rj", 
    api_key: "fb04ae401284be24afba0fbc2f4b0efb"
}, function(data) {
    // console.debug (data)
});

我在 Firebug 中收到以下错误:

missing ; before statement
[Break on this error] <lfm status="ok">\n

单击错误会将我带到从请求返回的文件。错误发生在第 2 行(实际上还有更多的轨道对象,但我只包含了一个用于长度的对象):

<?xml version="1.0" encoding="utf-8"?>
<lfm status="ok">
    <weeklytrackchart user="RJ" from="1278244800" to="1278849600">
        <track rank="1">
            <artist mbid="309c62ba-7a22-4277-9f67-4a162526d18a">Beck</artist>
            <name>Mixed Bizzness</name>
            <mbid></mbid>
            <playcount>2</playcount>
            <image size="small">http://userserve-ak.last.fm/serve/34/442288.jpg</image>
            <image size="medium">http://userserve-ak.last.fm/serve/64/442288.jpg</image>
            <image size="large">http://userserve-ak.last.fm/serve/126/442288.jpg</image>
            <url>www.last.fm/music/Beck/_/Mixed+Bizzness</url>
        </track>
    </weeklytrackchart>
</lfm>

那么错误就在返回的文件中,我该如何处理呢?谢谢阅读。

4

1 回答 1

3

这里有几件事是错误的。

首先,我认为JSONCallback=?您在请求 url 末尾的参数应该只是callback=?. 虽然令人困惑的是jQuery 文档在示例代码中显示了你的方式,但在正文中却没有......

另一件事是您正在使用该getJSON方法,而 Last.fm API 正在返回 XML,因此 jQuery 试图将返回的 XML 解析为 JSON,这显然无法做到。

因此,您需要指定您希望将 JSON 作为响应返回——这似乎可行:

$.getJSON('http://ws.audioscrobbler.com/2.0/?callback=?', {
    method: "user.getweeklytrackchart",
    user: "rj",
    api_key: "fb04ae401284be24afba0fbc2f4b0efb",
    format: "json"
}, function(data) {
    console.log(data);
});

您将能够在 Firebug 控制台中看到返回的 JSON 对象并检查它以查看您想要使用的数据。希望这可以帮助!

于 2010-07-16T12:31:21.760 回答