1

我有一个简单的问题,有一个带有参数 emp_id 的函数可以打开一个具有不同属性的聊天表单,我希望它每 10 秒自动刷新一次,现在它工作有点错误,因为有一个参数 emp_id是可以更改的,一旦我更改它,与消息和表单的聊天会刷新两次或三次:) 取决于你更改 emp_id 的次数,我希望我很清楚))无论如何这里是 javascript 函数:

function load_chat(emp_id) {
        var url = "#request.self#?fuseaction=objects2.popup_list_chatform"
        url = url + "&employee_id=" + emp_id;
        document.getElementById('form_div').style.display = 'block';                            AjaxPageLoad(url,'form_div',1,'Yükleniyor');
        setInterval( function() { 
            load_chat(emp_id); 
        },10000);
}

有一个名称列表,一旦我点击其中一个,这个表单就会被这个函数打开,但是如果我点击另一个用户,我的意思是如果我更改 emp_id,它会刷新以前和现在的表单。我如何更改它以使其仅刷新最后一个 emp_id,而不是我已更改的所有 id

谢谢大家的帮助,我真的很感激!

4

2 回答 2

2

这将很好地封装您正在做的事情。计时器 id ( tid) 保存在闭包内,因此当您调用load_chat它时,如果有一个正在运行,它将停止间隔。

设置新 url 后,它将再次启动间隔计时器。

var ChatModule = (function() {
    var tid,
    url;

    function refresh()
    {
        AjaxPageLoad(url, 'form_div', 1, 'Yükleniyor');
    }

    return {
        load_chat: function(emp_id) {
            if (tid) {
                clearInterval(tid);
            }
            // setup url
            url = "#request.self#?fuseaction=objects2.popup_list_chatform"
            url = url + "&employee_id=" + emp_id;
            document.getElementById('form_div').style.display = 'block';
            // load ajax
            refresh();
            // set timer
            tid = setInterval(refresh, 10000);
        }
    }
}());

ChatModule.load_chat(123);
于 2012-06-14T13:17:08.183 回答
0

改为使用setTimeout。每次执行您的函数时,它将设置下一次执行(您也可以使其有条件):

function load_chat(emp_id) {
    ... // do something
    if (condition_still_met)
        setTimeout(function() { 
            load_chat(emp_id); // with same id
        }, 10000);
}
load_chat("x"); // to start

否则您将不得不在load_chat函数之外使用 setInterval。您可以在必要时清除间隔。

function get_chat_loader(emp_id) {
    return function() {
        ... // do something 
    };
}
var id = setInterval(get_chat_loader("x"), 10000); // start

// then, somewhen later:
clearInterval(id);
于 2012-06-14T13:11:05.250 回答