0

好吧,我有一个有趣的问题。我的页面每隔一段时间就会发出一个 JSON 请求。如果数据没有改变,它不需要做任何事情。问题是,我无法找到一种方法来证明它是否已经改变。

我尝试过这样的事情无济于事:

var站=空;

function parseDynamicData(ard) {
    //this was something that gave me problems for days
    //nice little hack to fix it
    if (ard['details']['enabled'] == 'true' && ard['song']['art'] != 'undefined');
    {
        //turns off the 'server offline' page
        if (document.location.toString().indexOf('#offline') != -1)
            document.location = '/#tracks';
        //update UI
        $('#track-title').html(htmlDecode(ard['song']['title']));
        $('#track-artist').html(htmlDecode(ard['song']['artist']));
        $('#track-album').html(htmlDecode(ard['song']['album']));
        $('#track-art').attr('src', htmlDecode(ard['song']['art']));
        //set if it's play or pause visible
        if (htmlDecode(ard['details']['playing']) == 'true') {
            $('#control-pauseplay').html('Pause');
            $('#control-pauseplay').attr('href', '/track?proc=2');
        } else {
            $('#control-pauseplay').html('Play');
            $('#control-pauseplay').attr('href', '/track?proc=3');
        }
        //Now update all of the stations
        if (stations == null || stations != ard['stations']) {
            $.each(ard['stations'], function (key, value) {
                alert(key);
            });
            stations = ard['stations'];
        }
    }
}

这是正常的 JSON 响应的样子:

{
    "song": {
        "art": "http://cont-sjl-1.pandora.com/images/public/amz/6/2/3/3/886978533326_500W_500H.jpg",
        "title": "Hold It Against Me",
        "artist": "Britney Spears",
        "album": "Femme Fatale Deluxe"
    },
    "details": {
        "playing": "true",
        "enabled": "true"
    },
    "stations": {
        "undefined": "False",
        "Alex Clare Radio": "False",
        "Rap Strength Training Radio": "False",
        "Drops Of Jupiter Radio": "False",
        "Tween Radio": "False",
        "Today's Hits Radio": "True"
    }
}

然而,无论我做什么,它仍然会通过 JSON 为每个键发出警报。有人知道我应该怎么做吗?

4

2 回答 2

1

您可以尝试使用 JSON.Stringify 吗?显然,您从 JSON 请求返回的是 JSON,并且我假设您已将最后一个请求转换为实际的 Object。所以只需调用:

JSON.Stringify(Object) === JSONresult

并比较两个字符串。

于 2012-06-11T14:30:46.287 回答
1

我怀疑stationsard['stations']是结构相同的不同对象。如果您ard在每次 JSON 请求后进行重建,同时stations保留前一个 ard的数组,那么这两个对象不是同一个对象,因此无论对象是否具有相同的键值对,精确匹配都会失败。

我要做的是保留最后一条 JSON 消息的精确字符串副本,并在解析之前将其与当前 JSON 字符串消息进行比较。否则,您需要将当前对象的每一个键值对与预期的新对象进行比较——如果其中一些值本身就是对象,事情可能会变得有点(不必要的)麻烦。

如果您可以确定服务器将始终以相同的方式对给定对象O进行字符串化(并且假设您无需担心检查客户端上的对象是否已发生变异),那么您可以简单地比较 JSON 字符串版本来自服务器的对象。

于 2012-06-11T14:39:30.390 回答