javascript - IE 缓存问题破坏了我的查找字段

标签 javascript internet-explorer caching

我正在做一个项目,它使用 javascript 根据用户在字段中输入的文本(在每个按键上查询)从 View (用 Python 编写并使用 Django 界面)获取信息,然后显示该信息后退。基本上,这要么显示“找不到工作”,要么显示该工作的名称、用户名和余额。在 Firefox 中,这一切都非常有效。我可以输入一个 JobID,它告诉我该 ID 是新的,我可以创建该作业。然后我可以立即返回该页面并输入该 ID,我的查找将返回有关该职位的正确信息。

问题是,Internet Explorer 8 很懒。如果我在 IE8 中输入作业 ID,我的函数将调用查找页面 (/deposits/orglookup/?q=123) 并获取一个值。因此,例如,如果它变为 False,我就可以使用该 ID 创建一个新作业。如果我随后向后浏览并在同一查找字段中输入相同的数字,则 Internet Explorer 不会刷新查找页面,因此它会再次返回 false。如果我浏览到该查找页面,我会看到该错误值,但如果刷新它,我会再次获得正确的信息。知道如何在每次在查找字段中输入内容时强制执行此查询,而不是像 IE 那样引用缓存页面吗?

我要补充的是,在每个用户的基础上修复这个问题对我来说并没有多大好处,因为这是一个组织范围的应用程序,所以我真的可以使用一个修复程序,我可以在某个地方写入我的代码来强制 IE每次应该刷新查找页面。

这是查找函数的代码(如果有帮助的话)。它有点乱,但不是我写的,所以我会尝试包含所有相关内容:

$("#id_JobID").keyup( 

    function(event){

        //only fire gets on 0-9, kp 0-9, backspace, and delete
        if (event.keyCode in { 96:1, 97:1, 98:1, 99:1, 100:1, 101:1, 102:1, 103:1, 104:1, 105:1,
                                46:1,48:1, 49:1, 50:1, 51:1, 52:1, 53:1, 54:1, 55:1, 56:1, 57:1, 8:1}) 
        {

            if ($("#loadimg").attr("src") != "/static/icons/loading.gif") {
                $("#loadimg").attr("src", "/static/icons/loading.gif");
            }

            if ($("#loadimg").length < 1) {
                $("#id_JobID").parent().append("<img id=loadimg src=/static/icons/loading.gif>");
            }

            clearTimeouts(null); //clear all existing timeouts to stop any running lookups
            GetCounter++; 
            currLoc = window.location.href.slice(window.location.href.indexOf('?') + 1).split('/').slice(-2,-1);

            if (currLoc == 'restorebatch') {
                var TimeoutId = setTimeout(function() {dynamicSearch('restorelookup');}, 400);
            } else {
                var TimeoutId = setTimeout(function() {dynamicSearch('orglookup');}, 400);
            }

            //alert(TimeoutID);
            TimeoutBag[GetCounter] = {
                'RequestNumber': GetCounter,
                'TimeoutId': TimeoutId
            }
        }
    }
);

function clearTimeouts(TimeoutBagKeys) //TimeoutBagKeys is an array that contains keys into the TimeoutBag of Timeout's you want to clear
{
    if(TimeoutBagKeys == null) //if TimeoutBagKeys is null, clear all timeouts.
    {
        for (var i = 0; i < TimeoutBag.length; i++)
        {
           if (TimeoutBag[i] != null) {
            clearTimeout(TimeoutBag[i].TimeoutId);
           }
        }
    }
    else //otherwise, an array of keys for the timeout bag has been passed in. clear those timeouts.
    {
        var ClearedIdsString = "";
        for (var i = 0; i < TimeoutBagKeys.length; i++)
        {
            if (TimeoutBag[TimeoutBagKeys[i]] != null)
            {
                clearTimeout(TimeoutBag[TimeoutBagKeys[i]].TimeoutId);
                ClearedIdsString += TimeoutBag[TimeoutBagKeys[i]].TimeoutId;
            }
        }        
    }
}
function dynamicSearch(viewname) {

        $(".lookup_info").slideUp();


        if ($("#id_JobID").val().length >= 3) {
            var orgLookupUrl = "/deposits/" + viewname + "/?q=" + $("#id_JobID").val();
                getBatchInfo(orgLookupUrl);

        }
        else if ($("#id_JobID").val().length  == 0) {
            $("#loadimg").attr("src", "/static/icons/blank.gif");
            $(".lookup_info").slideUp();
        }
        else {
            $("#loadimg").attr("src", "/static/icons/loading.gif");
            $(".lookup_info").slideUp();
        }
}
function getBatchInfo(orgLookupUrl) {
                $.get(orgLookupUrl, function(data){ 
                    if (data == "False") {
                        $("#loadimg").attr("src", "/static/icons/red_x.png");
                        $(".lookup_info").html("No batch found - creating new batch.");
                        $("#lookup_submit").val("Create");
                        $(".lookup_info").slideDown();
                        toggleDepInputs("on");
                    }
                    else {  
                        $("#loadimg").attr("src", "/static/icons/green_check.png");
                        $("#lookup_submit").val("Submit");
                        $(".lookup_info").html(data);
                        $(".lookup_info").slideDown()
                        toggleDepInputs("off");
                    };
                 });
}

最佳答案

对此有以下三种解决方案:

  • 使用 $.post 而不是 $.get
  • 向您的网址添加随机 GET 参数,例如?update=10202203930489(当然,每个请求都需要不同)。
  • 通过发送正确的 header (if-modified-since) 来禁止服务器端缓存。

关于javascript - IE 缓存问题破坏了我的查找字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2075157/

相关文章:

javascript - 用js表格增值

javascript - jQuery:调用一个函数两次

javascript - 在提示中输入 3 个数字并在 JavaScript 中获取最大值

jQuery 动画在 IE 中不起作用

javascript - 使用 JavaScript 的 HTML 选择选项在 IE 中不起作用

caching - 如何告诉 cloudfront 不要缓存来自 S3 重定向的 302 响应,或者如何解决此图像缓存生成问题

javascript - 使用 Firefox Developer Tools 的多屏幕截图

html - IE11 输入类型 ="file"accept =".xls"附加类别出现

mysql - 什么是最好的 query_cache_size/Ram 比率

php - 使用 cURL PHP 与命令行 cURL 清除 Varnish 缓存