1

Internet Explorer でスクリプトが正しく動作しません。問題は、スクリプトが 1 回実行された後、「データ」(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パラメータをfalse次のように指定すると、Jquery はこれを自動的に行います。

$.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 に答える