加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

使用Ajax递归调用服务器端示例代码

发布时间:2020-12-16 01:41:12 所属栏目:百科 来源:网络整理
导读:程序中经常用到。需要大量占用服务器资源的运算,如导入,导出数据,经常出现超时错误。采用AJAX异步分批次调用,可以避免PHP出错。以下是示例代码。 public function getAjax() { $sid = 11222; $eid = 22332; $istep = 57; $getUrl = '/debug/doajax'; $js
程序中经常用到。需要大量占用服务器资源的运算,如导入,导出数据,经常出现超时错误。采用AJAX异步分批次调用,可以避免PHP出错。以下是示例代码。
 public function getAjax()
  {
      $sid = 11222;
      $eid = 22332;
      $istep = 57;

      $getUrl = '/debug/doajax';

       $js = <<<POSTTAG
<script type="text/javascript" src="/js/jquery/jquery-1.11.0.js"></script>
<script>
$(function(){

idfrom = {$sid};
idto = {$eid};
step = {$istep};

function newHttpGet(start,istep,idto)
{
  if (start > idto) return;  
  end = (start + istep < idto ) ?  start+istep : idto ;
  console.log('start'+start);
  console.log('end'+end);
  $.ajax({
    url:'{$getUrl}',type:'GET',dataType:'json',data:{
         psid : start,peid  : end,},async:'false',success:function(data)  {
          console.log(data);
          // if (data.status=='ok')
          // {
          //    alert(data.msg);  
          // }
          // else
          // {
          //   alert(data.msg);
          // }

          newHttpGet(start+istep,idto);
        },error:function(data){
            console.log("ajax 调用出错"+data);          
           
        }
   });    
}    
 
newHttpGet(idfrom,step,idto);

})
</script>
POSTTAG;
    return $js;
  }

  public function getDoajax()
  {
    if(Request::ajax())
    {
    //  sleep(1);
      $pid = Request::get('psid');
      $eid = Request::get('peid');
       return Response::json(['status'=>'ok','msg'=>'调用成功','pid'=>$pid,'eid'=>$eid]);
    }
  }

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读