【前端学习】—Promise基本知识(十六)

【前端学习】---Promise基本知识(十六)

一、class和function的区别

  • 相同点:都可以用作构造函数
  • 不同点:class不可以使用call apply bind的方式来改变它的执行上下文

二、Promise

定义:Promise是异步编程的一种解决方案,比传统的解决方案------回调函数和事件更合理和更强大。它是由社区最早提出和实现,ES6将其写进了语言标准,统一了用法,原生提供了Promise对象

三、代码演示

bash 复制代码
<script>

        //3个状态  pending fulfilled rejected
      new Promise(function (resolve, reject) {
        let fullName = "cai";
        if (fullName === "cai") {
          resolve(1);
        } else {
          reject(2);
        }
      }).then(
        function (value) {
          console.log(`resolve-value`, value);//resolve-value 1
        },
        function (value) {
          console.log(`reject-value`, value);
        }
      );
    </script>
bash 复制代码
<script>
      //Promise.prototype.then
      //可以支持链式调用
      //then接收的两个函数都是参数
      //第一个函数是Promise  状态变成fulfilled时候回调函数
      //第二个函数也是Promise 状态变成rejected的时候调用
      //返回值也是Promise(新的)

      new Promise(function (resolve, reject) {
        let fullName = "lily";
        if (fullName === "lily") {
          resolve(1);
        } else {
          reject(2);
        }
      })
        .then((value) => {
          console.log(`fulfilled value`, value);
          return value + 1;
        })
        .then(
          (fulfilledValue) => {
            console.log(`fulfilled value`, fulfilledValue);
          },
          (rejectedValue) => {
            console.log(`rejectedValue`, rejectedValue);
          }
        );
    </script>
bash 复制代码
//Promise.prototype.catch()捕获promise错误
      new Promise(function (resolve, reject) {
        let name = "ll";
        if (name === "llu") {
          resolve(1);
        } else {
          reject("promise error");
        }
      })
        .then((value) => {
          console.log(value);
        })
        .catch((error) => {
          console.log(error); //promise error
        });
bash 复制代码
 //Promise.prototype.finally()用于指定不管promise对象最后状态如何 都会执行的操作


      new Promise(function (resolve, reject) {
        console.log(`loading start......`)
        let name = "ll";
        if (name === "llu") {
          resolve(1);
        } else {
          reject("promise error");
        }
      })
        .then((value) => {
          console.log(value);
        })
        .catch((error) => {
          console.log(error); //promise error
        }).finally(()=>{
            console.log(`loading end......`)
        });
bash 复制代码
 // Promise.all
    //用于将多个Promise实例包装成一个新的Promise实例
      const promiseArray=[1,2,3,4,5].map((item)=>{
        return new Promise((resolve)=>{
            resolve(item);
        })
      })

      Promise.all(promiseArray).then(res=>{
        console.log(`res`,res);
      })
bash 复制代码
  // Promise.race方法是将多个promise实例,包装成一个新的Promise实例
      //Promise.race 继发(挨个发送)
      //Promise.all并发(多个一起发送)
       
        const promiseArray=[1,2,3,4,5].map((item)=>{
        return new Promise((resolve)=>{
            resolve(item);
        })
      })
      Promise.race(promiseArray).then(res=>{
        console.log(`res`,res);//res 1
      })
bash 复制代码
// Promise.resolve将现有对象 转换成Promise对象
Promise.resolve(1).then(res=>{
    console.log(res)//1
})
bash 复制代码
// Promise.reject 返回一个Promise实例 ------>rejected
Promise.reject('promise error').then(null,rejected=>{
    console.log(`rejected`,rejected)
})

四、ES6扩展运算符...实现原理

相关推荐
TeleostNaCl1 小时前
解决 Chrome 无法访问网页但无痕模式下可以访问该网页 的问题
前端·网络·chrome·windows·经验分享
charlie1145141911 小时前
CSS笔记4:CSS:列表、边框、表格、背景、鼠标与常用长度单位
css·笔记·学习·css3·教程
前端大卫3 小时前
为什么 React 中的 key 不能用索引?
前端
你的人类朋友3 小时前
【Node】手动归还主线程控制权:解决 Node.js 阻塞的一个思路
前端·后端·node.js
小李小李不讲道理4 小时前
「Ant Design 组件库探索」五:Tabs组件
前端·react.js·ant design
毕设十刻4 小时前
基于Vue的学分预警系统98k51(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末
前端·数据库·vue.js
✎ ﹏梦醒͜ღ҉繁华落℘5 小时前
FreeRTOS学习笔记(应用)-- 各种 信号量的应用场景
笔记·学习
星星火柴9365 小时前
笔记 | C++面向对象高级开发
开发语言·c++·笔记·学习
BeingACoder5 小时前
【SAA】SpringAI Alibaba学习笔记(一):SSE与WS的区别以及如何注入多个AI模型
java·笔记·学习·saa·springai
mapbar_front5 小时前
在职场生存中如何做个不好惹的人
前端