为了账号安全,请及时绑定邮箱和手机立即绑定

如何使 ajax 同步而不是使用 async:false?

如何使 ajax 同步而不是使用 async:false?

Go
慕的地6264312 2022-12-22 11:38:31
我在使用 ajax 异步时遇到了一些问题。我有一个数组,然后循环遍历该数组以进行 ajax 调用,如果成功,ajax 将返回一个 xml 字符串,我将使用它来填充表格并更新进程栏。我用async:false它在 Firefox 上运行良好,但在 Chrome 上运行不正常。我也试过用$.ajax().done(),但一点影响都没有。当 ajax 调用完成然后下一个循环将运行时,是否无论如何要获取响应的 xml 字符串?for (var i = 0; i <= arr.length; i++){    $.ajax({        url: '',        data: '',        async: false    }).done(function(xml) {       //get xml string to handle and put it into some table as contents    });    //Then go to next loop}
查看完整描述

3 回答

?
红糖糍粑

TA贡献1815条经验 获得超6个赞

不要试图使异步代码同步。您将锁定事件循环并受到严重的性能损失。


并行发出请求。将承诺收集在一个数组中。用于Promise.all确定它们何时全部完成。


然后你可以从它们中提取数据并用它做你想做的事。


例如:


const baseUrl = "https://jsonplaceholder.typicode.com/users/";

const userIds = [1,2,3,4,5];


const completeUrls = userIds.map( id => `${baseUrl}${id}` );

const promises = completeUrls.map( url => jQuery.ajax({url}) );

const collectedDataPromise = Promise.all(promises);


collectedDataPromise.then( data => {

    const names = data.map( user => user.name );

    const ul = $("<ul />");

    names.forEach( name => {

       ul.append( $("<li>").text(name) );

    });

    $("body").append(ul);

});

<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>


查看完整回答
反对 回复 2022-12-22
?
智慧大石

TA贡献1946条经验 获得超3个赞

最后,我得到了我自己的解决方案,我使用 async/await 来理解。


async function ajaxGetData(){

    return $.ajax({

               url: '',

               data: ''

          }).then(response => response.data);

}


async function hanldeResponse(){

   var arr = [1,2,...];

   for(var i = 0; i < arr.length; i++){

       let res = await ajaxGetData();

       //some code to handle the response with res variable

   }

}


查看完整回答
反对 回复 2022-12-22
?
慕田峪4524236

TA贡献1875条经验 获得超5个赞

如果你必须在每次迭代中更新数据,你可以使用一些字符串并在 .done() 中更新。


像这样递归试试:


var counter = arr.length;


function callAjax() {

  if (counter) {

    $.ajax({

      url: '',

      data: ''

    })

    .done(function(xml) {

      //get xml string to handle and put it into some table as contents

      counter--;

      callAjax();

    });

  }

}


查看完整回答
反对 回复 2022-12-22
  • 3 回答
  • 0 关注
  • 191 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号