ajax XMLHttpRequest的 onreadystatechange 为什么在send之前?

什么是 AJAX ?

AJAX = 异步 JavaScript 和 XML。

AJAX 是一种用于创建快速动态网页的技术。

通过在后台与服务器进行少量数据交换,AJAX 可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。

传统的网页(不使用 AJAX)如果需要更新内容,必需重载整个网页面。

有很多使用 AJAX 的应用程序案例:新浪微博、Google 地图、开心网等等。

AJAX 原理

在这里插入图片描述

手写一个简单的ajax

function lajax(url) {
  let ajax = new XMLHttpRequest()
  ajax.open('GET', url)
  ajax.onreadystatechange = () => {
    if(ajax.readyState == 4) {
      if(ajax.status == 200 || ajax.status == 304) {
        console.log(ajax.responseText)
      }else {
      }
    }
  }
  ajax.send()
}

可以看到 onreadystatechange 写在 send 之前,send 将请求发送到服务器,然后浏览器就会和服务器形成链接,连接过程中会不断收到响应数据,就会不断改变 readyState 的值,所以我们通过对 readyState 的判断就可以知道服务器相应的状态拿到数据

状态描述
0请求未初始化(在调用 open() 之前)
1请求已提出(调用 send() 之前)
2请求已发送(这里通常可以从响应得到内容头部)
3请求处理中(响应中通常有部分数据可用,但是服务器还没有完成响应)
4请求已完成(可以访问服务器响应并使用它)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值