zoukankan      html  css  js  c++  java
  • Promise对象的简单用法

    要了解一个东西,首先要从,它是什么、用来做什么以及怎么取用它这三个方面来了解。

    1. 首先,promise是什么?

    我们来参考一下MDN对它的定义:

    Promise 对象用于一个异步操作的最终完成(或失败)及其结果值的表示。(简单点说就是处理异步请求。我们经常会做些承诺,如果我赢了你就嫁给我,如果输了我就嫁给你之类的诺言。这就是promise的中文含义:诺言,一个成功,一个失败。)

    可以看到,promise是一个对象,用来处理异步操作,那么我们又要了解一下什么是同步异步,以下是我对同步异步的理解:

    异步:被请求人的消息通知机制,即当被请求者在接收到请求之后,处理请求,处理完成后是否通知请求者的消息通知机制。

    同步:请求者的事务处理机制,即当请求者发出请求后,是否等待请求结果,继续处理接下来的事务。

    总结promise是什么:

    promise是一个构造函数,用来处理javascript中的异步操作。

    1. promise用来做什么?
      在MDN的定义中已经给出答案,它用来处理异步操作,即维护事件处理的状态,方便我们对异步操作获取更直观的感受,就是在一个事件处理的过程中,监听事件处理的状态成功与否,然后由这些状态决定下一步操作。

    MDN中对promise有这样的描述:

    Promise 对象是一个代理对象(代理一个值),被代理的值在Promise对象创建时可能是未知的。它允许你为异步操作的成功和失败分别绑定相应的处理方法(handlers)。 这让异步方法可以像同步方法那样返回值,但并不是立即返回最终执行结果,而是一个能代表未来出现的结果的promise对象

    引用阮一峰ES6中的一句话介绍promise能为我们做什么,以及有什么缺点:

    有了Promise对象,就可以将异步操作以同步操作的流程表达出来,避免了层层嵌套的回调函数。此外,Promise对象提供统一的接口,使得控制异步操作更加容易。

    首先,无法取消Promise,一旦新建它就会立即执行,无法中途取消。其次,如果不设置回调函数,Promise内部抛出的错误,不会反应到外部。第三,当处于pending状态时,无法得知目前进展到哪一个阶段(刚刚开始还是即将完成)。

    1. 基本用法

    Promise是一个构造函数,用来生成Promise实例:

        var promise= new Promise(function(resolve,reject){
            //执行一些代码
            if(如果异步操作成功){
                resolve(value)
            }else{
                //异步操作失败
                reject(error)
            }
        })
    

    Promise对象通过维护三种状态来实现异步操作,这三种状态分别是:

    • pending:初始值,不是成功或失败状态
    • fulfilled :成功状态
    • rejected :操作失败状态

    在以上实例构建过程中:Promise在构建实例的过程总接受一个函数作为参数,这个函数又拥有两个函数作为参数(resolve,reject),分别代表着:

    • resolve函数的作用是将Promise对象的状态从“未完成”变为“成功”状态,在异步操作成功时调用,器参数为异步操作返回出的结果。
    • reject函数的作用则刚好相反,是将Promise对象的状态从“未完成”状态改变为“失败”状态,在异步操作失败时调用,其参数为异步操作失败返回的错误信息。

    Promise中的常用API

    • then
      作用:Promise对象根据异步操作结果,执行相应的回调函数,接受两个回调函数作为参数,第一个为Promise对象状态改变为resolved时调用,第二个回调函数为Promise对象状态改变为reject时调用,第二个参数是可选的,不是必须的,这两个函数都接受Promise传出的值作为参数。
    • catch
      作用:该方法是Promise.prototype.catch方法是.then(null, rejection)的别名,用于指定发生错误时的回调函数。
    • all
      作用:该方法用于将多个Promise实例包装成一个新的实例
        var  promise=Promise.all([p1,p2,p3])
        //该方法接受一个数组作为参数,数组中p1,p2,p3均为promise实例,只有当数组中的promise对象的状态全部为"成功"状态时,promise的状态才会变为成功状态,并将三个数组中的promise对象返回的结果,按照参数的顺序传递给promise的回调函数。
    
    只研朱墨作春山
  • 相关阅读:
    NET Core 2.2
    NET Core项目模板
    Eclipse同时显示多个控制台项目的输出
    Java中的序列化
    Java中的泛型
    Java中的集合
    Java中的数据结构
    Java中的包
    Java中的接口
    Java中的封装
  • 原文地址:https://www.cnblogs.com/guolintao/p/7821387.html
Copyright © 2011-2022 走看看