【ajax核心02】底层原理-Promise对象

目录

一:promise对象是什么

二:语法(Promise使用步骤)

三:Promise-三种状态


一:promise对象是什么

Promise 对象代表异步操作最终的完成(或失败)以及其结果值。

即Promise对象是用来管理一个异步任务最终状态结果值(then、catch)的对象

二:语法(Promise使用步骤)

//1.创建Promise对象
const p = new Promise((resolve,reject)=>{
//2.执行异步任务-并传递结果
//成功调用:resolve(值)方法,并触发then()执行
//失败调用:reject(值)方法,并触发catch()执行
})
//3.接收结果
p.then(result=>{
//成功
}).catch(error=>{
//失败
})

三:Promise-三种状态

一个Promise对象,必然处于以下几种状态之一

  • 待定(pending):初始状态,既没有兑现,也没有拒绝
  • 已兑现(fulfilled):操作成功完成
  • 已拒绝(rejected):操作失败

Promise对象一旦被兑现/拒绝两种状态中一种设置,就无法再更改状态

四:Promise.all

Promise.all用于合并多个Promise对象,等待所有Promise对象中请求同时成功(或某一个失败)后,再做后续逻辑

流程图如下:

语法:

const p = Promise.all([Promise对象,Promise对象,....])
p.then(result=>{
    //result结果:[Promise对象成功结果,Promise对象成功结果....]
}).catch(error=>{
    //第一个失败的Promise对象,抛出的异常
})

同时查询北京、上海、广州、深圳四地天气

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Promise的all方法</title>
</head>

<body>
  <ul class="my-ul"></ul>
  <script src="https://cdn.jsdelivr.net/npm/axios/dist/axios.min.js"></script>
  <script>
    /**
     * 目标:掌握Promise的all方法作用,和使用场景
     * 业务:当我需要同一时间显示多个请求的结果时,就要把多请求合并
     * 例如:默认显示"北京", "上海", "广州", "深圳"的天气在首页查看
     * code:
     * 北京-110100
     * 上海-310100
     * 广州-440100
     * 深圳-440300
    */
    const bObj = axios({ url: "https://hmajax.itheima.net/api/weather", params: { city: '110100' } })
    const sObj = axios({ url: "https://hmajax.itheima.net/api/weather", params: { city: '310100' } })
    const gObj = axios({ url: "https://hmajax.itheima.net/api/weather", params: { city: '440100' } })
    const szObj = axios({ url: "https://hmajax.itheima.net/api/weather", params: { city: '440300' } })
    const p = Promise.all([bObj, sObj, gObj, szObj])
    p.then(result => {
      // console.log(result);
      const Str = result.map(element => {
        return `<li>${element.data.data.area}--${element.data.data.weather}</li>`
      }).join('')
      document.querySelector('.my-ul').innerHTML = Str
    }).catch(error => {
      console.dir(error)
    })
  </script>
</body>

</html>

  • 9
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C# AJAX(Asynchronous JavaScript and XML)是一种用于在应用程序中现异步通信的技术。它许在不刷新个页面的情况下,通过与服务器进行异步通信来更新部分页面内容。 C# AJAX的底层实现原理主要包括以下几个方面: 1. XMLHttpRequest对象:C# AJAX使用XML对象来实现与服务器的异步通信。该对象可以在后台与服务器进行数据交换,而不会干扰到页面的显示和行为。通过该对象,可以发送HTTP请求并收服务器返回的数据。 2. 事件驱动模型:C# AJAX使用事件驱动模型来处理步通信过程中的各种事件。例如,可以通过监听XMLHttpRequest对象的onreadystatechange事件来获取服务器返回的数据,并在数据返回后执行相应的操作。 3. 数据格式:C# AJAX通常使用JSON(JavaScript Object Notation)或XML(eXtensible Markup Language)格式来传输数据。JSON是一种轻量级的数据交换格式,易于解析和生成;而XML是一种通用的标记语言,具有良好的可扩展性。 4. 服务器端处理:在服务器端,C# AJAX通常使用ASP.NET Web API或ASP.NET MVC等技术来处理异步请求。服务器端会根据请求的类型和参数,执行相应的逻辑,并将结果返回给客户端。 总的来说,C# AJAX的底层实现原理是通过XMLHttpRequest对象实现与服务器的异步通信,并使用事件驱动模型处理通过程中的各种事件。同时,使用JSON或XML格式传输数据,并在服务器端使用应的技术进行处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值