首页 > Web开发 > 详细

AJAX---onreadystatechange事件中获取相应内容和readystate状态

时间:2020-02-06 21:29:35      阅读:111      评论:0      收藏:0      [点我收藏+]

onreadystatechange事件中获取相应内容

 

    // 如果需要捕获第一个状态的变化,需要注意代码执行顺序的问题(不要出现来不及的情况)
    xhr.onreadystatechange = function () {
      // 这个事件并不是只在响应时触发,状态改变就触发
      // console.log(1)
      console.log(this.readyState)
    }

 

readystate状态

 

技术分享图片

 

技术分享图片

 

 

通过理解每一个状态值的含义得出一个结论:一般我们是在readyState值为4时,执行响应的后续逻辑

 

    var xhr = new XMLHttpRequest()
    console.log(xhr.readyState)
    // => 0
    // 初始化 请求代理对象

 

    xhr.open(‘GET‘, ‘time.php‘)
    console.log(xhr.readyState)
    // => 1
    // open 方法已经调用,建立一个与服务端特定端口的连接

 

 xhr.send()

 

xhr.addEventListener(‘readystatechange‘, function () {
      switch (this.readyState) {
        case 2:
          // => 2
          // 已经接受到了响应报文的响应头

          // 可以拿到头
          // console.log(this.getAllResponseHeaders())
          console.log(this.getResponseHeader(‘server‘))
          // 但是还没有拿到体
          console.log(this.responseText)
          break

        case 3:
          // => 3
          // 正在下载响应报文的响应体,有可能响应体为空,也有可能不完整
          // 在这里处理响应体不保险(不可靠)
          console.log(this.responseText)
          break

        case 4:
          // => 4
          // 一切 OK (整个响应报文已经完整下载下来了)
          console.log(this.responseText)
          break
      }

 

AJAX---onreadystatechange事件中获取相应内容和readystate状态

原文:https://www.cnblogs.com/jane-panyiyun/p/12269951.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!