Maison >interface Web >js tutoriel >Explication détaillée des instances d'objet Promise dans js
Supposons que j'aie maintenant une page de vérification du nom réel qui doit vérifier le numéro d'identification et le vrai nom. La vérification du nom réel est vérifiée par le système du ministère de la Sécurité publique (en supposant qu'elle soit vérifiée au préalable). la vérification est réussie, je vais enregistrer les informations actuelles du formulaire et me les soumettre en arrière-plan
La méthode 1 ne nécessite pas de promesse
//外层ajax,校验实名信息$.ajax({ type: "POST", url: "公安部检验真实姓名和身份证接口", dataType:"json", data: {name:"王尼玛",idCardNo:"4405************6543"}, success: function(msg){ if(msg.status) { //真实姓名、身份证号码验证通过,提交表单数据到本系统后台 $.ajax({ type: "POST", url: "/my/info.php", //本系统后台地址 dataType:"json", data: {表单数据}, success: function(msg){ if(msg.success) { //保存成功 } else { //保存失败 } } }); } else { //真实姓名、身份证号码错误 } } });Nous pouvons clairement voir que l'exemple ci-dessus nécessite une implémentation ajax imbriquée. Dans les exigences réelles, tout code ajax imbriqué sera très difficile à lire (plusieurs couches sont encore plus difficiles, bien sûr, certaines personnes utiliseront une implémentation ajax synchrone). , mais lorsque des requêtes ajax synchrones sont effectuées, la page utilisateur aura l'impression d'être morte [rire et pleurer] 】;
La méthode 2 utilise la promesse
new Promise(function (resolve, reject) { $.ajax({ type: "POST", url: "公安部检验真实姓名和身份证接口", dataType: "json", data: { name: "王尼玛", idCardNo: "4405************6543" }, success: function (msg) { if (msg.status) { resolve(msg); //真实姓名、身份证号码通过验证,msg会传入then方法的第一个方法参数 } else { reject(msg); //真实姓名、身份证号码未通过验证,msg会传入then方法的第二个方法参数 } } }); }).then(function (resolveMsg) { $.ajax({ type: "POST", url: "/my/info.php", //本系统后台地址 dataType: "json", data: { "表单数据": "表单数据" }, success: function (msg) { if (msg.success) { //保存成功 } else { //保存失败 } } }); } , function (rejectMsg) { //真实姓名、身份证号码错误 });
Résumé Permettez-moi d'abord de parler de la conclusion : Promise convient au rappel ajax asynchrone imbriqué multicouche
.
new Promise().then() .then() .then() .catch();format, la structure est très claire Recommandations associées :
Tutoriel sur l'utilisation de base de Promise
Utiliser Promise pour simplifier les rappels
Analyse des instances de promesse en js
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!