Maison >interface Web >js tutoriel >JavaScript la méthode .then / .when.
Aujourd'hui, je suivais un tutoriel WordPress et l'instructeur montrait comment effectuer une recherche sur le site à l'aide de jQuery et de JavaScript, en utilisant spécifiquement les méthodes .then() et .when(). En suivant, j’ai réalisé que je n’étais pas aussi familier avec ces méthodes que je le pensais.
J'ai donc fait quelques recherches, pris quelques notes et les ai ajoutées à mon carnet Obsidian. Pour être honnête, les notes sont plutôt grossières : elles ressemblent à quelque chose qu'un élève de cinquième année avec la capacité d'attention d'un écureuil pourrait mettre en place (ce qui, avouons-le, me ressemble parfois !).
Mais je me suis dit, pourquoi ne pas les partager ? S’ils aident ne serait-ce qu’une seule personne, cela vaut la peine d’être publié.
Vous êtes à l'école, et vous et vos amis vous faites des promesses. Ces promesses reviennent à dire : « Je finirai mes devoirs, et ensuite nous pourrons jouer à des jeux. »
Mais voici le problème : il faut parfois un peu de temps pour terminer les devoirs. Vous pourriez le finir rapidement, ou peut-être que votre chien le mange, et vous ne le finirez jamais (oups !). Les Promesses JavaScript fonctionnent de la même manière. Il attend que quelque chose se passe, puis il dit : « D'accord, et ensuite ? »
La méthode .then() ressemble à ce que vous ferez après la promesse est faite. Imaginez que vous disiez à votre ami :
Mais que se passe-t-il si vous ne terminez pas ? Oh-oh, vous pouvez ajouter un plan de sauvegarde :
Voici comment vous diriez cela en JavaScript :
promiseToFinishHomework .then(() => { console.log("Yay! We can play games!"); // If you finished }) .catch(() => { console.log("Oh no! No games today!"); // If you didn’t finish });
C'est comme lorsque vous attendez un groupe de vos amis pour finir leurs devoirs pour que vous puissiez tous jouer ensemble. Vous êtes comme :
Dans la vraie vie, ça s’appelle travailler ensemble. En JavaScript, vous utilisez quelque chose appelé Promise.all() (ce qui revient à dire « Attendons que tout le monde soit prêt ! ») :
Promise.all([friend1, friend2]).then(() => { console.log("We’re all done! Time to play!"); });
Ainsi, JavaScript s'assure simplement de savoir ce qui se passe ensuite lorsque les promesses sont tenues ou non ! ?
La promesse ne vérifie pas les devoirs par elle-même. Vous le dites ! Lorsque vous créez une promesse, vous décidez si elle est résolue ou rejetée selon que la tâche (comme finir les devoirs) est terminée ou non. Le .then() s'exécute lorsque la promesse est résolue et .catch() s'exécute lorsqu'elle est rejetée.
Voici un exemple complet pour le voir en action :
let promiseToFinishHomework = new Promise((resolve, reject) => { let finishedHomework = true; // Change this to false to see the rejection if (finishedHomework) { resolve(); // Homework is done! } else { reject(); // Homework is not done! } }); promiseToFinishHomework .then(() => { console.log("Yay! We can play games!"); // If the promise resolves (homework done) }) .catch(() => { console.log("Oh no! No games today!"); // If the promise rejects (homework not done) });
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!