首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何在另一个函数中调用setinterval函数无效

如何在另一个函数中调用setinterval函数无效
EN

Stack Overflow用户
提问于 2015-01-12 07:02:35
回答 1查看 503关注 0票数 1

我希望在Ajax进程进行时显示更新记录计数。当我单击start process按钮时,updateRecords()函数将执行,它将在database.So中将记录状态逐个更新为等待状态,同时希望在用户单击strat按钮时显示等待记录计数.For,当用户单击使用setinterval调用displayWaitingRecords()时。

我是这样从updateRecords()调用这个函数的

代码语言:javascript
运行
复制
clear_Process = setInterval(function(){displayWaitingRecords()},200);

但是displayWaitingRecords()不会调用,直到updateRecords() process completes.But,我的要求是displayWaitingRecords()也会与updateRecords()一起简单地执行。

函数显示更新的记录计数。

代码语言:javascript
运行
复制
function displayWaitingRecords()
{
    jQuery.ajax({
        type: 'GET',
        crossDomain:true,
        async: false,
        url: "/curlRRQCount.php",
        success: function(count){
            if(count)
            {
                jQuery("#processed_poids_div").html("Processed Order ids:"+count) ;
            }                 
        }
    });  
}

函数时,单击“开始处理”按钮。

代码语言:javascript
运行
复制
var clear_Process = "";
function updateRecords()
{
    clear_Process = setInterval(function(){displayWaitingRecords()},200);  
    var str = jQuery("#rrq_form :input[value!='']").serialize();
    jQuery.ajax({
        async: false,
        type: 'POST',
        data : str,
        url: "/updaterecord_status.php",
        success: function(valid_result)
        {
            if(jQuery.trim(valid_result) == 'Success')
            {
                jQuery("#rrq_load_img").hide();
                jQuery("#rrq_orders_status").html("some success message");
            }
        }
    }); 
}

我在哪里做错事?任何帮助都将不胜感激。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-01-12 08:04:17

你设置了async: false。因此ajax调用将处理同步的过程。将其设置为false或将其排除在外(因为true是默认的):

代码语言:javascript
运行
复制
var clear_Process = "";
function updateRecords()
{
    clear_Process = setInterval(function(){displayWaitingRecords()},200);  
    var str = jQuery("#rrq_form :input[value!='']").serialize();
    jQuery.ajax({
        async: true,
        type: 'POST',
        data : str,
        url: "/updaterecord_status.php",
        success: function(valid_result)
        {
            if(jQuery.trim(valid_result) == 'Success')
            {
                jQuery("#rrq_load_img").hide();
                jQuery("#rrq_orders_status").html("some success message");
            }
        }
    }); 
}

如果你忽略了它,你就会得到同样的结果:

代码语言:javascript
运行
复制
function displayWaitingRecords()
{
    jQuery.ajax({
        type: 'GET',
        crossDomain:true,
        url: "/curlRRQCount.php",
        success: function(count){
            if(count)
            {
                jQuery("#processed_poids_div").html("Processed Order ids:"+count) ;
            }                 
        }
    });  
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/27896869

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档