码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Promise——promise是什么?为什么要用promise?


    目录

    • Promise是什么?
    • 为什么要用Promise?
      • 指定回调函数的方式和更加灵活
      • 支持链式调用,可以解决回调地狱的问题。
        • 1. 什么是回调地狱?
        • 2. 回调地狱的缺点?
        • 3. 解决方案?

    Promise是什么?

    1. 抽象表达:
    • Promise是一门新的技术(ES6规范)
    • Promise是JS中进行异步编程的新的解决方案。
      (旧方案是单纯的使用回调函数)
      备注:异步编程包括fs文件操作,数据库操作,AJAX,定时器
    1. 具体表达:
    • 从语法上来说:Promise就是一个构造函数
    • 从功能上来说:Promise对象用来封装一个异步操作并可以获取其成功或者失败的和结果值。

    为什么要用Promise?

    指定回调函数的方式和更加灵活

    1. 旧的:必须在启动异步任务前指定
    2. promise:启动异步任务=>返回promise对象=>给promise对象绑定回调函数。(甚至可以在异步任务结束后指定多个)

    支持链式调用,可以解决回调地狱的问题。

    1. 什么是回调地狱?

    回调函数嵌套调用,外部回调函数异步执行的结果是嵌套的回调的执行的条件。
    
    • 1
    getData() {
      axios.get("./mock/data_a.json").then((res1) => {
        console.log(res1.data.code);
        axios.get("./mock/data_b.json").then((res2) => {
          console.log(res2.data.code);
          axios.get("./mock/data_c.json").then((res3) => {
            console.log(res3.data.code);
          });
        });
      });
    },
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    2. 回调地狱的缺点?

    (1) 嵌套过多会影响代码的可读性和逻辑
    (2) 当某个请求失败时难以定位问题,这情况被称为回调地狱

    3. 解决方案?

    promise链式调用

    methods:{
      getData1(url) {
        return new Promise((resolve, reject) => {
          axios.get(url).then((res1) => {
            if (res1.data.code <= 1) {
              resolve("成功");
            } else {
              reject("失败");
            }
          });
        });
      },
    }
    
    
    mounted(){
    	this.getData1("./mock/data_a.json")
        .then((res) => {
          console.log(res);
          return this.getData1("./mock/data_b.json");
        })
        .then((res) => {
          console.log(res);
          return this.getData1("./mock/data_c.json");
        })
        .then((res) => {
          console.log(res);
        })
        .catch((err) => {
          console.log(err);
        });
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
  • 相关阅读:
    汉诺塔-python递归
    鼠标右键助手专业版 MouseBoost PRO for Mac v3.3.6中文破解
    论文阅读 Fast Reinforcement Learning Via Slow Reinforcement Learning
    如何快速创建SQL Server数据库服务并远程连接?
    sched,进程调度窥探,进程调度直观感受
    全媒体整合营销时代,如何做好网络营销?
    pcl中MomentOfInertiaEstimation解析与实例
    Linux - 进一步理解 文件系统 - inode - 机械硬盘
    CICD流水线
    热搜榜:最热门的话题文本排行榜API接口
  • 原文地址:https://blog.csdn.net/weixin_52148548/article/details/126103653
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号