ES6---promise详解及用法

本文详细介绍了Promise的概念、使用场景、好处及特点。Promise是ES6提供的异步编程解决方案之一,用于处理异步操作及其结果,有效避免回调地狱问题。文章还探讨了Promise的状态、实例方法和对象方法等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、什么是Promise

Promise是ES6异步编程的一种解决方案(目前最先进的解决方案是async和await的搭配(ES8),但是它们是基于promise的),从语法上讲,Promise是一个对象或者说是构造函数,用来封装异步操作并可以获取其成功失败的结果。
 

二、为什么要使用promise

最重要也是最主要的一个场景就是ajax和axios请求。通俗来说,由于网速的不同,可能你得到返回值的时间也是不同的,但是我们下一步要执行的代码依赖于上一次请求返回值,这个时候我们就需要等待,结果出来了之后才知道怎么样继续下去。 

三、promise的好处

1.可以避免多层异步调用嵌套问题(回调地狱)
2.Promise 对象提供了简洁的API,使得控制异步操作更加容易(js执行机制导致的异步问题
这两点在我ES6专栏的相关文章有很详细的介绍,这里就不展开了

 四、promise的三种状态

Promise对象有三种状态,他们分别是:

1.pending: 等待中,或者进行中,表示还没有得到结果
2.resolved(Fulfilled): 已经完成,表示得到了我们想要的结果,可以继续往下执行
3.rejected: 也表示得到结果,但是由于结果并非我们所愿,因此拒绝执行 

这三种状态不受外界影响,而且状态只能从pending改变为resolved或者rejected,并且不可逆

五、promise的用法 

1.promise的实例方法

①then()得到异步任务的正确结果

②catch()获取异常信息


③finally()成功与否都会执行(尚且不是正式标准)
 注意:then方法可以接受两个函数,第一个函数为promise状态为成功的回调函数,第二个函数为promise状态为失败的回调函数可以不写,一般用catch方法捕获promise状态为失败的异常信息)

 2.promise的对象方法(p1,p2,p3为promise的实例对象)

①Promise.all()并发处理多个异步任务所有任务都执行完成才能得到结果

Promise.all( [p1,p2,p3] ) .then ( (result) => {consoleog (result)
})

②Promise.race()并发处理多个异步任务只要有一个任务完成就能得到结果
 

Promise.race ( [p1,p2,p3] ).then ( (result)=>{
console. log (result)
})

六、promise的特点 

1.在Promise对象的构造函数中,将一个函数作为第一个参数

2.而Promise对象的构造函数的第一个参数中的这个函数,就是用来处理Promise的状态变化,这个函数的第一个参数表示promise的状态为成功第二个参数表示promise的状态为失败,这两个参数(名字可以自己命名都为一个函数,他们的作用分别是将promise状态修改为resolved(成功)rejected(失败)。

 

    <script>
        function fn(flag) {
            //构造函数
               return new Promise(function(resolve, reject) {
                if (flag === true) {
                    resolve('promise状态为成功!')
                };
                if (flag === false) {
                    reject('promise状态失败!')
                };
            })
        }

        console.log(fn(true));
    </script>

 控制台运行:

3. Promise对象中的then方法,可以接收构造函数中处理的状态变化,并分别对应执行。then方法有2个函数参数第一个函数接收resolved(promise状态为成功)的执行,第二个函数接收reject(promise状态为失败)的执行。 

 

    <script>
        function fn(flag) {
            return new Promise(function(resolve, reject) {
                if (flag === true) {
                    resolve('promise状态为成功!')
                };
                if (flag === false) {
                    reject('promise状态失败!')
                };
            }).then(function(res) {
                    console.log(res);
                },
                function(err) {
                    console.log(err);
                })
        }
        fn(true)
        fn(false)
    </script>

控制台运行:

4.promise的状态只能从 未完成->完成, 未完成->失败 且状态不可逆转。

promise的异步结果,只能在完成状态时才能返回,而且我们在开发中是根据结果来选择来选择状态的,然后根据状态来选择是否执行then()。

实例化的Promise内部会立即执行,then方法中的异步回调函数会在脚本中所有同步任务完成时才会执行。因此,promise的异步回调结果最后输出。示例代码如下:
 

var promise = new Promise(function(resolve, reject) {
  console.log('Promise instance');
  resolve();
});

promise.then(function() {
  console.log('resolved result');
});
for(var i=0;i<100;i++) {
console.log(i);
/*
Promise instance
1
2
3
...
99
100
resolved result
*/

 5.Promise.then()方法

①then()函数返回的实际也是一个Promise对象(无论函数内部返回什么类型的数据,函数都会进行加工返回一个promise对象

    <script>
        function fn(flag) {
            return new Promise(function(resolve, reject) {
                if (flag === true) {
                    resolve('promise状态为成功!')
                };
                if (flag === false) {
                    reject('promise状态失败!')
                };
            })
        }
        console.log(fn(true).then());
    </script>

控制台运行:

 

 ②then()函数内部返回为普通值(非Promise类型的属性),返回的普通值会直接传递给下一个then,通过then参数中函数的参数接收该值。

这时then()函数返回的Promise对象状态为成功(resloved),then()函数的返回值为对象的成功值,如return 123,返回的Promise对象值为123,如果没有返回值,是undefined

    <script>
        const p = new Promise((resolve, reject) => {
            setTimeout(() => {
                resolve('用户数据');
            })
        });
        let result = p.then(value => {
            return 123;
        }, reason => {
            console.log(reason)
        })
        console.log(result);
        result.then(function(res) {
            console.log(res);
        })
    </script>

控制台运行:

  

③ 当then()函数内部返回的是Promise类型的对象时,then()函数的返回的Promise对象的状态值为这个Promise对象的状态值,成功值也是如此,返回的该promise对象会调用下一个then方法。

    <script>
        const p = new Promise((resolve, reject) => {
            setTimeout(() => {
                resolve('用户数据');
            })
        });
        let result = p.then(value => {
            return new Promise((resolve, reject) => {
                resolve('ok')
            })
        }, reason => {
            console.log(reason)
        })
        console.log(result);
        result.then(function(res) {
            console.log(res);
        })
    </script>

控制台运行:

 

 ④当then()函数内部果抛出异常,则then()函数的返回值状态也是rejected

    <script>
        const p = new Promise((resolve, reject) => {
            setTimeout(() => {
                resolve('用户数据');
            })
        });
        let result = p.then(value => {
            throw 123
        }, reason => {
            console.log(reason)
        })
        console.log(result);
    </script>

控制台运行:

 

 

6.Promise.catch()方法

①catch()函数只有一个回调函数,意味着如果Promise对象状态为失败就会调用catch()方法并且调用回调

//catch()函数只有一个回调函数,意味着如果Promise对象状态为失败就会调用catch()方法并且调用回调函数
<script>
const p = new Promise((resolve, reject) => {
setTimeout(()=>{
reject('出错啦')
},1000)
})

p.catch(reason => {
console.log(reason)
})
</script>

控制台运行:   

七、总结

1.promise其实就是一个对象或者说是构造函数

2.promise的出现(es6) 就是解决异步编程和回调地狱等问题,async和await的出现(ES8)就是基于promise的一种解决异步编程的终极解决方案(简化代码等等)

 3.在前端中,ajax和axios都会用到异步编程axios更是基于promise的,所以一定要掌握promise以及用async和await搭配promise的使用

 

### JavaScriptPromise 的使用方法 #### 1. 基本概念 Promise 是一种用于处理异步操作的对象,它可以表示一个尚未完成但最终会完成的操作及其结果。通过 `new Promise` 可以创建一个新的 Promise 实例[^2]。 以下是创建 Promise 对象的基本语法: ```javascript let promise = new Promise((resolve, reject) => { // 执行一些异步操作 if (/* 异步操作成功 */) { resolve(value); // 成功时调用 resolve 方法 } else { reject(error); // 失败时调用 reject 方法 } }); ``` #### 2. 使用 `.then()` 和 `.catch()` `.then()` 方法可以用来指定当 Promise 被解决(fulfilled)时的回调函数,而 `.catch()` 则是用来捕获错误的回调函数[^1]。 下面是一个简单的例子来展示如何使用 `.then()` 和 `.catch()` 来处理 Promise 的结果: ```javascript let promise = new Promise((resolve, reject) => { let success = true; if (success) { resolve("Operation was successful"); } else { reject(new Error("Something went wrong")); } }); // 当 Promise 解决时执行 onFulfilled 函数 promise.then( (message) => console.log(message), // 输出: Operation was successful (error) => console.error(error.message) ); // 或者单独使用 .catch() promise.catch((error) => console.error(error.message)); // 如果有错误则输出错误消息 ``` #### 3. 链式调用 Promise 支持链式调用多个 `.then()` 方法,这使得我们可以依次处理一系列依赖于前一步骤的结果的任务[^3]。 示例如下: ```javascript let promise = new Promise((resolve, reject) => { resolve(1); }); promise .then((value) => value + 1) // 返回新的 Promise 并传入下一个 then .then((newValue) => newValue * 2) .then((finalValue) => console.log(finalValue)) // 输出: 4 .catch((err) => console.error(err)); ``` #### 4. 错误处理的最佳实践 为了更好地管理错误,推荐总是附加 `.catch()` 方法到 Promise 链条上来捕捉任何未被捕获的异常[^1]。 ```javascript function fetchData(url) { return new Promise((resolve, reject) => { // 模拟网络请求 setTimeout(() => { const error = false; if (!error) { resolve(`Data from ${url}`); } else { reject('Failed to fetch data'); } }, 1000); }); } fetchData('/api/data') .then(data => console.log(data)) .catch(error => console.error(error)); ``` ---
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Cirrod

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值