七校项目中使用promise处理回调地狱问题

Posted theworldofbeisong

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了七校项目中使用promise处理回调地狱问题相关的知识,希望对你有一定的参考价值。

//封装一个promise
var ajaxPromise = function(param){
		return new Promise(function(suc,fail){
			debugger;
			console.log(param)
                       //ajax请求
			$.ajax({
				url:param.url,
				type:"post",
				async:false,
				data:param.data,
				dataType:"json",
				success: function(res) {
					suc(res);
				      },
				error: function(err) {
				   fail(err);
		      }
			})
		})
	}
	var step1 = ajaxPromise({url:‘Student_getStudentInfo‘,data:{phoneNum:sessionPhoneNum}})
		.then(function(res){
			console.log("jjjjj");
                        //返回一个新的之前封装的promise
			return ajaxPromise({url:"ApplyForm_getSchoolList",data:{}})
		})
		.then(function(res){
			console.log("gsjgj");
		},function(err){
			console.log("jfdhskjfhsdfhsj");
		})
		.catch(function(err){
			console.log(ajaxPromise);
			console.log("fkdjskjsdk");
		})
});    

  then方法里面可以有两个函数  第一个是当将Promise的状态变为fuifill的时候,后面一个函数是将promise状态变为reject的时候,

     但是其实catch也可以处理这样的reject 以及本来就需要处理的异常的报错所以不能简单党的将then理解为请求成功时执行的

以上是关于七校项目中使用promise处理回调地狱问题的主要内容,如果未能解决你的问题,请参考以下文章

基于PROMISE解决回调地狱问题

39.JavaScript中Promise的基本概念使用方法,回调地狱规避链式编程

promise解决回调地狱

js-promise以及asyncawait

javascript异步代码的回调地狱以及JQuery.deferred提供的promise解决方式

JS的Promise兄弟