手写promise自定义封装异步任务回调的执行

简介: 手写promise自定义封装异步任务回调的执行

自定义封装异步任务回调的执行


<script type="text/javascript">
    let p = new Promise((resolve, reject) => {
        setTimeout(() => {
            reject('err');
        }, 1000)
    })
    // 这个then方法是由p这个promise调用的
    p.then(res => {
        console.log('res', res)
    }, err => {
        console.log(err)
    })
</script>


我们发现 1s 后并没有输出内容值


为什么回调没有去执行呢?


因为代码从上往下执行的时候


setTimeout(() => {
    reject('err');
}, 1000)是一个异步的;


然后去执行下面的代码,它是不会去等待异步的哈~


去执行下面的同步代码


p.then(res => {
    console.log('res', res)
}, err => {
    console.log(err)
})


然后去调用了p的then方法;


我们到知道,p的状态一直没有发生改变;


一直是pedding


而我们封装的Promise中的then方法中没有对pedding判定进行判断


状态一直没有发生变化


所以一直是无法输出内容


如何解决上面遇见的问题


我们现在要解决,1s后的成功回调这个问题;


我们知道,状态的改变是在resolve和reject中


所以,我们是要在对应的函数中去处理这个问题的哈


首先保存成功或者失败后的回调函数


<script src="./Promise.js"></script>
<script type="text/javascript">
    let p = new Promise((resolve, reject) => {
        setTimeout(() => {
            reject('err');
        }, 1000)
    })
    // 这个then方法是由p这个promise调用的
    p.then(res => {
        console.log('res', res)
    }, err => {
        console.log(err)
    })
    console.log(p)  //此时是可以输出保存的回调函数的哈
</script>


function Promise(executor){
    const self=this;
    function resolve(data){
        // 如果状态发生改变就直接返回(为了让Promise的状态只发生一次改变);
        if( self.PromiseStatus!=='pending') return
        self.PromiseStatus='resolved';
        self.PromiseValue=data;
    }
    // 同样声明成为一个函数;修改状态
    function reject(err){
        // 如果状态发生改变就直接返回(为了让Promise的状态只发生一次改变);
        if( self.PromiseStatus!=='pending') return
        self.PromiseStatus='rejected';
        self.PromiseValue=err;
    }
    this.PromiseStatus ='pending' ;
    this.PromiseValue =null;
    // 声明属性  -----提供后面的成功或者失败后回调函数的使用
    this.callBack={};
    // 对异常进行处理;使用try catch
    try{
        executor(resolve,reject);
    }catch(err){
        reject(err);
    }
}
// 自定义封装then方法执行回调
Promise.prototype.then=function(onResolve,onReject){
    //{PromiseStatus:"resolved"PromiseValue:"ok"}
    if(this.PromiseStatus==='resolved'){
        onResolve(this.PromiseValue)
    }
    if(this.PromiseStatus==='rejected'){
        onReject(this.PromiseValue)
    }
    // 如果是pending的状态
    if(this.PromiseStatus==='pending'){
        // 这个是保存回调函数
        this.callBack={
            onResolve:onResolve,
            onReject:onReject
        }
    }
}


这个时候,我们打印 p


我们是知道 callBack 是有回调函数的;


自定义封装异步任务回调的执行(完整篇)


<script src="./Promise.js"></script>
<script type="text/javascript">
    let p = new Promise((resolve, reject) => {
        setTimeout(() => {
            reject('err');
        }, 1000)
    })
    // 这个then方法是由p这个promise调用的
    p.then(res => {
        console.log('res', res)
    }, err => {
        console.log(err)
    })
    console.log(p)
</script>


function Promise(executor){
    const self=this;
    function resolve(data){
        // 如果状态发生改变就直接返回(为了让Promise的状态只发生一次改变);
        if( self.PromiseStatus!=='pending') return
        self.PromiseStatus='resolved';
        self.PromiseValue=data;
        // 调用成功的回调函数
        if(self.callBack.onResolve){
            self.callBack.onResolve(data)
        }
    }
    // 同样声明成为一个函数;修改状态
    function reject(err){
        // 如果状态发生改变就直接返回(为了让Promise的状态只发生一次改变);
        if( self.PromiseStatus!=='pending') return
        self.PromiseStatus='rejected';
        self.PromiseValue=err;
        // 调用失败的回调函数
        if(self.callBack.onReject){
            self.callBack.onReject(err)
        }
    }
    this.PromiseStatus ='pending' ;
    this.PromiseValue =null;
    // 声明属性 ,提供后面的成功或者失败后回调函数的使用
    this.callBack={};
    // 对异常进行处理;使用try catch
    try{
        executor(resolve,reject);
    }catch(err){
        reject(err);
    }
}
// 自定义封装then方法执行回调
Promise.prototype.then=function(onResolve,onReject){
    //{PromiseStatus:"resolved"PromiseValue:"ok"}
    if(this.PromiseStatus==='resolved'){
        onResolve(this.PromiseValue)
    }
    if(this.PromiseStatus==='rejected'){
        onReject(this.PromiseValue)
    }
    // 如果是pending的状态
    if(this.PromiseStatus==='pending'){
        // 这个是保存回调函数
        this.callBack={
            onResolve:onResolve,
            onReject:onReject
        }
    }
}


我学到的东西;
原来可以这样将回调函数保存起来
// 声明属性 ,提供后面的成功或者失败后回调函数的使用
 this.callBack={};
// 这个是保存回调函数
this.callBack={
    onResolve:onResolve,
    onReject:onReject
}
// 调用成功的回调函数
if(self.callBack.onResolve){
    self.callBack.onResolve(data)
}


相关文章
|
25天前
|
前端开发 JavaScript
如何使用 Promise 处理异步并发操作?
通过使用 `Promise.all()` 和 `Promise.race()` 方法,可以灵活地处理各种异步并发操作,根据不同的业务需求选择合适的方法来提高代码的性能和效率,同时也使异步代码的逻辑更加清晰和易于维护。
|
25天前
|
存储 前端开发
除了 Promise.all(),还有哪些方法可以处理异步并发操作?
在上述示例中,`concurrentPromises` 函数接受一个Promise数组和最大并发数作为参数,通过手动控制并发执行的Promise数量,实现了对异步操作的并发控制,并在所有Promise完成后返回结果数组。
|
22天前
|
前端开发 数据处理
如何使用 Promise.all() 处理异步并发操作?
使用 `Promise.all()` 可以方便地处理多个异步并发操作,提高代码的执行效率和可读性,同时通过统一的 `.catch()` 方法能够有效地处理异步操作中的错误,确保程序的稳定性。
|
26天前
|
JSON 前端开发 JavaScript
在 JavaScript 中,如何使用 Promise 处理异步操作?
通过以上方式,可以使用Promise来有效地处理各种异步操作,使异步代码更加清晰、易读和易于维护,避免了回调地狱的问题,提高了代码的质量和可维护性。
|
25天前
|
前端开发 JavaScript 开发者
用 Promise 处理异步操作的优势是什么?
综上所述,使用Promise处理异步操作能够有效地解决传统回调函数带来的诸多问题,提高代码的质量、可读性、可维护性和可扩展性,是JavaScript中进行异步编程的重要工具和技术。
|
2月前
|
前端开发 JavaScript UED
深入了解JavaScript异步编程:回调、Promise与async/await
【10月更文挑战第11天】深入了解JavaScript异步编程:回调、Promise与async/await
21 0
|
3月前
|
前端开发 JavaScript
解决异步问题,教你如何写出优雅的promise和async/await,告别callback回调地狱!
该文章教授了如何使用Promise和async/await来解决异步编程问题,从而避免回调地狱,使代码更加清晰和易于管理。
解决异步问题,教你如何写出优雅的promise和async/await,告别callback回调地狱!
|
7月前
|
前端开发 JavaScript
如何处理 JavaScript 中的异步操作和 Promise?
如何处理 JavaScript 中的异步操作和 Promise?
67 1
|
7月前
|
前端开发 JavaScript
在JavaScript中,什么是promise、怎么使用promise、怎么手写promise
在JavaScript中,什么是promise、怎么使用promise、怎么手写promise
105 4
|
7月前
|
前端开发 JavaScript 开发者
JavaScript 中的异步编程:Promise 和 Async/Await
在现代的 JavaScript 开发中,异步编程是至关重要的。本文将介绍 JavaScript 中的异步编程概念,重点讨论 Promise 和 Async/Await 这两种常见的处理异步操作的方法。通过本文的阐述,读者将能够更好地理解和应用这些技术,提高自己在 JavaScript 开发中处理异步任务的能力。