javascript - XMLHttpRequest、readyState 问题

标签 javascript xmlhttprequest

在网页中,我正在使用 XMLHttpRequest。 我遇到了麻烦,因为事情不会像往常一样发生。

相关代码如下:

  let xmlHttp = new XMLHttpRequest(); 
  xmlHttp.onreadystatechange = function() {
    if (this.readyState == 4 && this.status == 200) {
      // Here useful work is done.
      .......
    }
  }

  xmlHttp.open("GET","readUser.php?EL="+user.email,true);
  xmlHttp.send();

但最近由于某种原因,这种情况正在发生:

this.status == 200 (as expected)

但是:

this.readyState == 3 (and not 4 as usual)

结果,“有用的工作”没有完成。

如何让“this.readyState”回到 4?

或者我怎样才能找到为什么“this.readyState”不是它应该的 4?

我使用 XMLHttpRequest 的经验相当有限,所以当出现像这里这样的问题时,我有点不知所措。除了我在旁边(独立地)运行“readUser.php?EL=somemail@example.com”之外。没有问题,我也没有发现任何问题。

我已经尝试使用 Firefox、Chrome 和 Safari,得到相同的行为;所以我认为这不是浏览器相关的问题。

++++++ 作为引用,readUser是一个PHP页面,这里是readUser.php中的相关代码

<?php
....
ConnectToDB();

$query = 'SELECT * FROM MyDBTable';
$query .= sprintf(" WHERE MlAdr='%s'",$_GET['EL']);
$DBS=$Connection->query($query);
$DBS->setFetchMode(PDO::FETCH_ASSOC);
$dataJSON = json_encode($DBS->fetch());
echo $dataJSON;
?>

最佳答案

代替 xmlHttp.onreadystatechange 使用

xmlHttp.onload = function() {
  if (this.status == 200) {
    // Here useful work is done.
    .......
  }
}

xhr (XMLHttpRequest) 方法很老 - 考虑使用更现代的方法:fetch .

关于javascript - XMLHttpRequest、readyState 问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57505295/

相关文章:

循环时 JavaScript .children HTML 集合长度问题

javascript - 使用 moment-hijri.js 调整伊斯兰日期

javascript - 如何在 jQuery Each 循环中保存对上下文的更改?

javascript - 我们在 React 中使用哪些钩子(Hook)来更新和删除?

web-services - HTTP 上的 XML 和 HTTP 上的 SOAP 之间的区别

javascript - 阻止来自潜在可信来源的混合内容 (127.0.0.0/8)

javascript - XML 请求中的文件提前结束错误

javascript - 使用 jQuery 获取每个 html 输入的最后一个括号名称

javascript - 以编程方式滚动外部网页以加载内容

javascript - 表达 res.redirect() 返回 HTML 而不是重定向