IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> JavaScript——我眼中的Promise -> 正文阅读

[JavaScript知识库]JavaScript——我眼中的Promise

最近做一个项目,需要对之前的同步代码进行修改,此时我发现,之前我面试时所谈及的promise在应用中一点也不懂,看文档自己写了一个demo,让我似乎明白了promise使用问题。

1. 代码示例

const promise1 = function (){
    return new Promise((resolve, reject) => {
        let a = 0;
        setTimeout(() => {
            a = 111
            resolve(a)
        }, 800)
    })
}
const promise2 = function (str){
    return new Promise((resolve, reject) => {
        setTimeout(() => {
            str++
            resolve(str)
            // reject()
        }, 400)
    })
}
const promise = new Promise((resolve, reject) => {
    const res1 = promise1();
    resolve(res1)
}).then((res) => {
    console.log(res, '上一步的结果')
    const res2 = promise2(res)
    return res2
}).then((res) => {
    console.log(res, '最终结果')
}).catch(err => {
    console.log('\x1b[91m',`报错啦:${err}`)
}).finally(() => {
    console.log("执行结束")
})

运行结果:
111 上一步的结果
112 最终结果
执行结束

2. 代码解析

  • 我需要按顺序执行两个函数promise1、promise2
  • 首先定义两个函数,使用定时器的方式模拟网络请求
  • 在我执行promise时,接收两个参数resolve、reject。
  • resolve表示放行,让函数继续向后面执行,可以在resolve传递数值,给then中的res
  • reject表示停止,当发生异常或报错时,可以阻止继续向下执行
  • 在第一个.then函数中,我们return的res2是promise2函数的结果。此时我们在then函数中return出去的也是一个promise,那么就受定义的promise2函数的影响。若promise2中resolve,并且传值,那么我在此处是可以获取到的,并且在下一个then中的res就是promise2函数的结果,也会等待promise2函数执行结束后才会向下执行。
  • catch捕捉在函数执行时所发生的错误信息,不要让函数运行卡死
  • finally表示无论函数能否正确执行/异常执行,最终都会执行这项操作。

总结用法,希望可以帮助到你,
我是Ably,你无须超越谁,只要超越昨天的自己就好~

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-03-12 17:23:13  更:2022-03-12 17:24:30 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 7:36:57-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码