1

我的脚本无法在 Internet Explorer 中正常工作。问题是'data'(JSON.stringify(data);)在脚本运行一次后没有用新值更新,它用与第一次相同的值更新div跑。我是js新手,不知道如何解决这个问题。感谢帮助!

function ful() {
    $.ajax({
        url: 'api.php',
        data: "",
        dataType: 'json',
        success: function(data) {
            var imp = "";
            var imps = new Array();
            var set = new Array();
            var div1, div2, div3, div4, tmp, hum, tid = "";
            var temp = "";
            var humi = "";
            imp = JSON.stringify(data);
            var values = imp.split(',');
            var i = 0;
            var y = 0;
            for (var x = 0; x < values.length; x++) {
                imps[y] += values[x];
                i++;
                if (i == 4) {
                    y++;
                    i = 0
                }
            }
            for (var x = 0; x < imps.length; x++) {
                div1 = "impid" + x;
                div2 = "temp" + x;
                div3 = "hum" + x;
                div4 = "tid" + x;
                set = imps[x].split('"');
                tmp = set[9];
                hum = set[13];
                tid = set[17];
                for (var y = 0; y < tmp.length; y++) {
                    temp += tmp[y];
                    if (y == 4) break;
                }
                for (var y = 0; y < hum.length; y++) {
                    humi += hum[y];
                    if (y == 4) break;
                }
                document.getElementById(div1).textContent = "ID : " + set[5];
                document.getElementById(div2).textContent = "Temprature : " + temp + " °C";
                document.getElementById(div3).textContent = "Humidity : " + humi + " %";
                document.getElementById(div4).textContent = tid;
                temp = "";
                humi = "";
                tmp = "";
                tid = "";
                hum = "";
            }
        }
    });
    setTimeout(ful, 6000)
}
$(ful);
4

1 回答 1

3

Internet Explorer 缓存 ajax 请求。

一个简单的解决方法是在请求的末尾添加一个时间戳,强制 IE 获取一个新的。cache当指定参数时,Jquery 会自动为您执行此操作false

$.ajax({
    url: 'api.php',
    data: "",
    dataType: 'json',
    cache: false,
    success: ...

有关其他选项,请查看此帖子: https ://devcentral.f5.com/blogs/us/fixing-internet-explorer-amp-ajax#.UcIVBZyiVSQ

于 2013-07-02T13:13:13.267 回答