第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問(wèn)題,去搜搜看,總會(huì)有你想問(wèn)的

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

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

Go
慕的地6264312 2022-12-22 11:38:31
我在使用 ajax 異步時(shí)遇到了一些問(wèn)題。我有一個(gè)數(shù)組,然后循環(huán)遍歷該數(shù)組以進(jìn)行 ajax 調(diào)用,如果成功,ajax 將返回一個(gè) xml 字符串,我將使用它來(lái)填充表格并更新進(jìn)程欄。我用async:false它在 Firefox 上運(yùn)行良好,但在 Chrome 上運(yùn)行不正常。我也試過(guò)用$.ajax().done(),但一點(diǎn)影響都沒(méi)有。當(dāng) ajax 調(diào)用完成然后下一個(gè)循環(huán)將運(yùn)行時(shí),是否無(wú)論如何要獲取響應(yīng)的 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貢獻(xiàn)1815條經(jīng)驗(yàn) 獲得超6個(gè)贊

不要試圖使異步代碼同步。您將鎖定事件循環(huán)并受到嚴(yán)重的性能損失。


并行發(fā)出請(qǐng)求。將承諾收集在一個(gè)數(shù)組中。用于Promise.all確定它們何時(shí)全部完成。


然后你可以從它們中提取數(shù)據(jù)并用它做你想做的事。


例如:


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>


查看完整回答
反對(duì) 回復(fù) 2022-12-22
?
智慧大石

TA貢獻(xiàn)1946條經(jīng)驗(yàn) 獲得超3個(gè)贊

最后,我得到了我自己的解決方案,我使用 async/await 來(lái)理解。


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

   }

}


查看完整回答
反對(duì) 回復(fù) 2022-12-22
?
慕田峪4524236

TA貢獻(xiàn)1875條經(jīng)驗(yàn) 獲得超5個(gè)贊

如果你必須在每次迭代中更新數(shù)據(jù),你可以使用一些字符串并在 .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();

    });

  }

}


查看完整回答
反對(duì) 回復(fù) 2022-12-22
  • 3 回答
  • 0 關(guān)注
  • 161 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)