您好,登錄后才能下訂單哦!
本篇內容介紹了“怎么封裝一個可以終止的Promise”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
function MyPromise(callback) {
// 1、在Pormise外部定義變量
let _resolve;
let _reject;
const promise = new Promise((resolve, reject) => {
// 2、在Pormise內部將promise的resolev和reject方法賦值給外部變量
_resolve = resolve;
_reject = reject;
callback && callback(resolve);
})
return {
promise,
_reject
}
}
let p1 = MyPromise(function (reslove) {
setTimeout(() => {
reslove(1000)
}, 3000);
})
let p2 = MyPromise(function (reslove) {
setTimeout(() => {
reslove(2000)
}, 3000);
})
let p3 = MyPromise(function (reslove) {
setTimeout(() => {
reslove(3000)
}, 3000);
})
p1.promise.then(data => {
console.log(data)
return p2.promise;
}).then(data => {
console.log(data)
return p3.promise;
}).then(data => {
console.log(data)
}).catch(e => console.log(e))
// 此處p3可以更改為p1或p2,根據需求終止promise調用鏈
p3._reject(444)
“怎么封裝一個可以終止的Promise”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。