Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/459.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 将异步函数及其回调函数分配给单个变量_Javascript - Fatal编程技术网

Javascript 将异步函数及其回调函数分配给单个变量

Javascript 将异步函数及其回调函数分配给单个变量,javascript,Javascript,在完成下面的函数之后,我的下一个任务是让它每3秒循环一次 Chat.fetch(function(x) // x is an array delivered by .fetch { for (var i = 0; i<x.length; i++) { Chat.display(x[i]); // and .display only takes strings as an argument } }); 然后

在完成下面的函数之后,我的下一个任务是让它每3秒循环一次

  Chat.fetch(function(x) // x is an array delivered by .fetch
    {
      for (var i = 0; i<x.length; i++)
        {
          Chat.display(x[i]); // and .display only takes strings as an argument
        }
    });
然后我会做一些类似的事情

setInterval(myvariable, 3000);

显然,这不起作用。是什么让这个函数停止了这种方法?

我会提出一个不同的解决方案

// define the callback function
var displayMessages = function(x) // x is an array delivered by .fetch
    {
      for (var i = 0; i<x.length; i++)
        {
          Chat.display(x[i]); // and .display only takes strings as an argument
        }
      // Ivoke Chat.fetch with this callback again after 3 seconds
      setTimeout( function(){ Chat.fetch( displayMessages ); }, 3000 );
    } 
// start polling
Chat.fetch( displayMessages );
//定义回调函数
var displayMessages=function(x)//x是由.fetch传递的数组
{

对于(var i=0;i我将提出不同的解决方案

// define the callback function
var displayMessages = function(x) // x is an array delivered by .fetch
    {
      for (var i = 0; i<x.length; i++)
        {
          Chat.display(x[i]); // and .display only takes strings as an argument
        }
      // Ivoke Chat.fetch with this callback again after 3 seconds
      setTimeout( function(){ Chat.fetch( displayMessages ); }, 3000 );
    } 
// start polling
Chat.fetch( displayMessages );
//定义回调函数
var displayMessages=function(x)//x是由.fetch传递的数组
{

对于(var i=0;iYou很接近。
var myvariable=function(){Chat.fetch(etc.)}
。您很接近。
var myvariable=function(){Chat.fetch(etc.)}
。谢谢你,先生。我看到专业人士似乎喜欢setTimeout,但是setInterval有点不稳定吗?我在你的有用提示后10秒就开始工作了。
setInterval
可能不太可预测。服务器响应时间、网络延迟、脚本执行时间在这里起作用。例如,你启动了
聊天。获取
,服务器ver阻塞,处理此特定请求需要5秒钟,但在3秒钟后,您再次启动了
聊天。获取
,响应立即到达。现在您的消息显示顺序错误。从回调调用
设置超时
可确保在处理上一个请求后发出下一个请求。谢谢你,先生。我看到专业人士似乎喜欢setTimeout,但是setInterval有点不稳定吗?我在你的有用提示后10秒就开始工作了。
setInterval
可能不太可预测。服务器响应时间、网络延迟、脚本执行时间在这里起作用。例如,你启动了
聊天。获取
,服务器cho处理此特定请求需要5秒钟,但3秒钟后,您再次启动了
Chat.fetch
,响应立即到达。现在,您的消息以错误的顺序显示。从回调调用
setTimeout
可确保在处理上一个请求后发出下一个请求。