定期发送ajax请求

时间:2013-04-17 07:59:27

标签: javascript jquery ruby-on-rails ruby ajax

有一个页面,我想定期制作"背景" ajax请求。所以页面加载然后它应该在一定的时间内发送ajax请求。

我可能会使用cron。我以前从未使用过,所以我想知道它是否适合这项任务。还有其他更简单的方法吗?

P.S。时间延迟约为5分钟。

5 个答案:

答案 0 :(得分:7)

由于在您发出AJAX请求的时间和收到完整响应的时间之间存在一个未知的延迟,因此通常更优雅的方法是在固定的时间内启动下一个AJAX调用之前完成之后。这样,您还可以确保您的通话不会重叠。

var set_delay = 5000,
    callout = function () {
        $.ajax({
            /* blah */
        })
        .done(function (response) {
            // update the page
        })
        .always(function () {
            setTimeout(callout, set_delay);
        });
    };

// initial call
callout();

答案 1 :(得分:4)

Cron在服务器端运行,你正在使用HTML和AJAX,所以你应该在Javascript中解决这个问题: - )

通过使用类似setInterval之类的东西你可以继续执行一个函数,你的情况可能就像通过AJAX轮询网址一样:

function updatePage(){
  // perform AJAX request
}
setInterval(updatePage, 5000);

答案 2 :(得分:1)

根据您的rails版本,您可以使用periodically_call_remote,否则您将需要@Bitterzoet描述的jquery替代方案。

更多信息in this question

答案 3 :(得分:1)

您可以在四秒内发送ajax请求,如下所示:

setInterval(get_news, 4000);
        function get_news(){
             $.ajax('/dashboards/get_news', {
                type: 'POST',
                success: function(result) {
                    if(result > 0){
                        $('#div_1').text("See "+result+" new messages");
                        $('#div_1').show();
                    }
                    else{
                        $('#div_1').css('display', 'none');
                    }
                     },
                error: function() {
                    // alert("Error")
                }
            });       

        }

答案 4 :(得分:1)

你在使用jquery吗?如果是这样,您可以实现此方法:

// first, you need asing a callback timer
var timeout = 300; //milliseconds

// this method contain your ajax request
function ajaxRequest() { //function to ajax request
    $.ajax({
        url: "/url/to/request/"
    }).done(function(data) {
        alert("response is: " + data);
    });
}


$(document).on("ready", function(){

    //this method will be called every 300 milliseconds
    setInterval(ajaxRequest, timeout);
});