ES6的Promise -- 逻辑执行的顺序
Promise的核心价值是创建一个异步执行的过程,并给你善后的机会。
Promise对象一但创建就会立即执行,执行过程是异步的,不会对后续的逻辑造成阻塞。
直接声明,立即执行
let promise = new Promise ( (resolve, reject) => { //执行耗时的逻辑。。。 if ( success ) { resolve(a) // pending ——> resolved 参数将传递给对应的回调方法 } else { reject(err) // pending ——> rejectd } } ) //后续代码会继续执行,而不是等待Promise内部逻辑执行完毕。 //...
放到函数里,需要时执行
function promise () { return new Promise ( function (resolve, reject) { //执行耗时的逻辑。。。 if ( success ) { resolve(a) } else { reject(err) } } ) }
Promise内逻辑执行完毕后,调用resolve还是reject,完全要看编程者的意图。调用resolve就会触发Promise的then,调用reject就会触发Promise的catch。
这就是设计的价值之处,执行完毕一个耗时操作后,给你一个条件回调的机会用于执行后续逻辑。
promise.then( () => { console.log('this is success callback') } ).catch( (err) => { console.log(err) } )
更多
then() 和 catch() 都会返回一个新的Promise对象,可以链式调用。
promise.then( () => { console.log('this is success callback') } ).catch( (err) => { console.log(err) } ).then( ... ).catch( ... )
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。