我正在尝试构建一个网络应用程序,从服务器获取数据并将其显示给用户。脚本每 10 秒从服务器获取数据,如果数据发生更改,它会提醒用户。这是我现在使用的代码,但它每 10 秒提醒一次数据是否已更改。
那么我需要如何更改我的 scipt 以使其比较旧 JSON 和新 JSON 并查看它们是否不同,以及它们在更新向用户显示的数据之前是否显示警报?
$('#ListPage').bind('pageinit', function(event) {
getList1();
});
setInterval ( "getList1()", 10000 );
var old = "";
function getEmployeeList1() {
$.getJSON(serviceURL + 'getemployees.php?' + formArray, function(data) {
if(data != old){ // data from the server is not same as old
$('#nollalista li').remove();
keikka = data.key;
$.each(keikka, function(index, lista) {
$('#nollalista').append('<li><a href="employeedetails.html?id=' + lista.IND + '">' +
'<h4>' + lista.OSO + '</h4>' +
'<p>' + lista.AIKA + '</p>' +'</a></li>');
});
$('#nollalista').listview('refresh');
if(old != "")
alert("New data!");
old = data;
}
});
}
最佳答案
一个非常简单(但有点蹩脚)的解决方案是比较字符串表示:
if(JSON.stringify(a) != JSON.stringify(b)) { ... }
关于JavaScript JSON 比较,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10188931/