javascript - Concernant le chargement asynchrone Ajax, veuillez poser des questions sur le problème de retard des données
阿神
阿神 2017-06-30 09:53:44
0
6
697

Définissez un tableau vide à l'extérieur, puis effectuez une requête ajax, imbriquez une autre requête à l'intérieur de la requête, et enfin divisez-la en trois objets et insérez le tableau vide.
Ensuite, j'imprime la longueur du tableau sur le côté le plus extérieur et la longueur imprimée est 0. Ce problème affectera l'affectation. S'il vous plaît dites-moi comment le résoudre.

阿神
阿神

闭关修行中......

répondre à tous(6)
为情所困

L'asynchronie

ajax peut causer de tels problèmes. Solution 1. Promesse 2. Attribuez une valeur dans le rappel ajax

ringa_lee

ajax est asynchrone Lorsque votre code de journal est exécuté, ajax n'est pas encore revenu.

学霸

Veuillez vérifier le problème de la boucle d'événement

Nous savons qu'ajax est une opération asynchrone,

L'emplacement de votre console.log À l'heure actuelle, arr.length est en fait [].length

.

Une fois votre js actuel exécuté, le rappel de succès ajax sera exécuté Ce n'est qu'une fois le rappel de succès réussi que votre tableau arr sera poussé dans la valeur

.

Vous voudrez peut-être mettre console.log dans le deuxième rappel de succès ajax
Quant à la promesse, cela optimisera très bien ce rappel imbriqué, mais vous devez encapsuler votre ajax

Il est recommandé d'emballer tous vos ajax dans des promesses

为情所困

ajax est une méthode d'acquisition de données asynchrone, donc les données acquises de manière asynchrone ne peuvent pas être traitées de la manière synchrone que nous comprenons habituellement. Vous devez écrire votre console.log dans la fonction de rappel de réussite.

过去多啦不再A梦

Définissez votre async: false afin que vous puissiez obtenir la valeur à l'intérieur de l'extérieur.

巴扎黑

Dans ce cas, vous devez passer à la synchronisation ajax. S'il est asynchrone, ajax et le code derrière sont exécutés en même temps

Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal