XDomainRequest в IE- "свежие" данные только при первом вызове
Я использую JSON-запрос для получения некоторой информации о потоке на разрабатываемой веб-странице. Для совместимости с IE я использую XDomainRequest. XDR успешно извлекает данные во время первой загрузки страницы, но последующие вызовы (я использую windows.setInterval на странице после загрузки) не возвращают обновленную информацию. Очистка кэша браузера тоже ничего не дает. Единственный способ, которым страница будет загружать новые данные, - это фактически перезапустить IE и загрузить страницу. Что мне не хватает??
Вот мой код XDR:
//Now Access & Process the NWS Gage Data
if ($.browser.msie && window.XDomainRequest) {
//Internet Explorer Doesn't support JQuery's getJSON so you must use an alternative method
// Use Microsoft XDR
var xdr = new XDomainRequest();
xdr.open("get", "http://waterservices.usgs.gov/nwis/iv/?format=json&sites=12150800,12167000,12161000,12150400,12138160,12134500,12186000,12155300,12155500¶meterCd=00065");
xdr.onload = function () {
//parse response as JSON
var JSON = $.parseJSON(xdr.responseText);
if (JSON == null || typeof (JSON) == 'undefined')
{
JSON = $.parseJSON(data.firstChild.textContent);
}
array.forEach(JSON.value.timeSeries, function(curGage, i){
curGageID = curGage.sourceInfo.siteCode[0].value;
curGageName = curGage.sourceInfo.siteName;
curGageHeight = curGage.values[0].value[0].value;
curGageObs = curGage.values[0].value[0].dateTime;
//Another Internet Explorer quirk. Date format must be changed due to IE's different interpretation
curGageObs = curGageObs.replace(/\-/g,"/");
curGageObs = curGageObs.replace(/T/g," ");
curGageObs = curGageObs.substring(0,curGageObs.length-10);
var theDate = new Date(curGageObs);
document.getElementById('u' + curGageID + 'Height').innerHTML = curGageHeight + " Feet";
document.getElementById('u' + curGageID + 'Date').innerHTML = theDate.toString('M/d/yyyy @ h:mm tt');
assignNwsStageColor(curGageID, curGageHeight);
});
};
xdr.send();
} else {
$.getJSON("http://waterservices.usgs.gov/nwis/iv/?format=json&sites=12150800,12167000,12161000,12150400,12138160,12134500,12186000,12155300,12155500¶meterCd=00065", function(data) {
array.forEach(data.value.timeSeries, function(curGage, i){
curGageID = curGage.sourceInfo.siteCode[0].value;
curGageName = curGage.sourceInfo.siteName;
curGageHeight = curGage.values[0].value[0].value;
curGageObs = curGage.values[0].value[0].dateTime;
var theDate = new Date(curGageObs);
document.getElementById('u' + curGageID + 'Height').innerHTML = curGageHeight + " Feet";
document.getElementById('u' + curGageID + 'Date').innerHTML = theDate.toString('M/d/yyyy @ h:mm tt');
assignNwsStageColor(curGageID, curGageHeight);
});
});
}
Спасибо! Стив
1 ответ
Решение
Если вы хотите убедиться, что вы не получаете кэшированную информацию от вызова ajax, вы можете добавить метку времени к URL.
Например:
$.getJSON("http://example.com?param1=asdf&_=" + new Date().getTime());