javascript - 關(guān)于ajax異步加載請(qǐng)問數(shù)據(jù)延遲問題
問題描述
在外面定義一個(gè)空數(shù)組,然后做一個(gè)ajax請(qǐng)求,請(qǐng)求內(nèi)再嵌套一個(gè)請(qǐng)求,最終拼接成一個(gè)三個(gè)對(duì)象插入空數(shù)組。然后我在最外面打印數(shù)組長度,打印出來的長度是0,這個(gè)問題會(huì)影響賦值。請(qǐng)問怎么解決。
問題解答
回答1:ajax異步會(huì)造成這樣的問題。解決方案1.Promise 2.在ajax回調(diào)中進(jìn)行賦值
回答2:ajax 是異步的,當(dāng)執(zhí)行到你的 log 代碼時(shí),ajax 還沒有返回呢。
回答3:請(qǐng)查閱事件循環(huán)的問題
我們知道ajax是異步操作,
你console.log 的位置 此時(shí)arr.length 其實(shí)就是[].length
當(dāng)你當(dāng)前的js執(zhí)行完后,ajax的success回調(diào)才會(huì)執(zhí)行,只有success回調(diào)成功后此時(shí)你的arr數(shù)組被push進(jìn)值
所以你可能要把console.log放入第二個(gè)ajax的success回調(diào)里至于promise會(huì)很好的優(yōu)化這種嵌套的回調(diào),但是你要封裝你的ajax
建議把你所有的ajax 包裝成promise
回答4:ajax是數(shù)據(jù)獲取方式是異步的,所以異步獲取的數(shù)據(jù)并不能按照平時(shí)理解的同步方式去處理,應(yīng)該把你的console.log 寫在 success 的 回調(diào)函數(shù)里。
回答5:將你的async:false,這樣你就可以在外面獲取到里面的值了。
回答6:這樣的話,你得改成ajax同步。異步的話,ajax和它后面的代碼同時(shí)執(zhí)行
相關(guān)文章:
1. mysql - 這種分級(jí)一對(duì)多,且分級(jí)不平衡的模型該怎么設(shè)計(jì)表?2. javascript - vue-cli npm run build編譯報(bào)錯(cuò)3. python - Scrapy ItemLoader數(shù)據(jù)清洗疑問4. PHP類屬性聲明?5. javascript - Object.define 可以監(jiān)聽object變化,那基本類型變量如何監(jiān)聽6. css - div外層有一圈白色7. atom開始輸入!然后按tab只有空格出現(xiàn)沒有html格式出現(xiàn)8. javascript - js setTimeout在雙重for循環(huán)中如何使用?9. python - pip install出現(xiàn)下面圖中的報(bào)錯(cuò) 什么原因?10. javascript - vue 2.0 :key的作用
