美文网首页
Promise相关概念

Promise相关概念

作者: 池鱼_故渊 | 来源:发表于2021-03-08 15:29 被阅读0次

    Promise 检测图片

    检测图片是否加载成功,成功就正常显示,失败就展示默认图片

    import Vue from "vue";
    // 图片失败指令, 因为口袋贵金属用户有些头像无法显示
    // 全局注册自定义指令,用于判断当前图片是否能够加载成功,可以加载成功则赋值为img的src属性,否则使用默认图片
    Vue.directive("gkoudai-avatar-img", async function(el) {
      // 指令名称为:real-img
      let imgURL = el.getAttribute("src"); // 获取图片地址
      if (imgURL) {
        let exist = await imageIsExist(imgURL);
        if (!exist) {
          el.setAttribute(
            "src",
            "url"
          );
        }
      }
    });
    
    /**
     * 检测图片是否存在
     * @param url
     */
    let imageIsExist = function(url) {
      return new Promise(resolve => {
        var img = new Image();
        img.onload = function() {
          if (this.complete === true) {
            resolve(true);
            img = null;
          }
        };
        img.onerror = function() {
          resolve(false);
          img = null;
        };
        img.src = url;
      });
    };
    

    休眠的实现方法

    function sleep(interval) {
      return new Promise(resolve => {
        setTimeout(resolve, interval);
      })
    }
    // 用法
    async function one2FiveInAsync() {
      for(let i = 1; i <= 5; i++) {
        console.log(i);
        await sleep(1000);
      }
    }
    one2FiveInAsync();
    

    基本用法

    const promise = new Promise(function(resolve, reject) {
      // ... some code
      if (/* 异步操作成功 */){
        resolve(value);
      } else {
        reject(error);
      }
    });
    promise.then(function(value) {
      // success
    }, function(error) {
      // failure
    });
    

    有一点需要注意,如果是new Promise 那么是立刻执行里面的代码 promise.then才是微任务

    Promise.prototype.finally()

    finally()方法用于指定不管 Promise 对象最后状态如何,都会执行的操作。该方法是 ES2018 引入标准的。

      let P = this.constructor;
      return this.then(
        value  => P.resolve(callback()).then(() => value),
        reason => P.resolve(callback()).then(() => { throw reason })
      );
     };
    

    不管最后是成功还是失败都会执行finally中的callback 这个我们可以把成功或者失败后需要操作的代码都拿到finally中去写

    Promise.all()

    Promise.all()方法用于将多个 Promise 实例,包装成一个新的 Promise 实例。
    const p = Promise.all([p1, p2, p3]);
    p1,p2,p3的状态都成功了,那么p的状态才成功,否则有一个失败了那么p的状态就会失败

    Promise.race()

    和Promise.all()很相似,不同点是,接受多个promise实例,有一个成功那么p的状态就是成功的,率先成功的,会把结果传递给p的回调函数

    Promise.allSettled()

    这个是ES2020新添加的属性,接受一组Promise实例,等待所有实例都完成,那么p的状态才会改变,有时候我们只关系我们的操作是否结束,不关心结果,all()就不太好用,那么allSettled就会比较符合场景

    Promise.any()

    接收一组promise实例,只要有一个实例 成功了那么p状态就是成功的,只有当所有状态都失败了,那么p的状态才会失败

    Promise.try()

    让同步函数同步,让异步函数异步,更好的处理结果和错误,不用管自己代码是异步还是同步

      .then(...)
      .catch(...)
    

    相关文章

      网友评论

          本文标题:Promise相关概念

          本文链接:https://www.haomeiwen.com/subject/bvipqltx.html