我正在试图了解XMLHttpRequest()
对象是如何工作的。
如果删除xhr.send()
,"hi"
将显示。但当它出现时,什么也不会显示出来。我真的很想将xhr.status
写到屏幕上,但是首先我需要知道为什么脚本没有完成执行,即使其余部分不依赖于xhr.send()
之后的响应。
<html>
<head>
<title>Playground</title>
</head>
<body>
<div>
<script>
var xhr = new XMLHttpRequest();
xhr.open("GET","http://www.google.com",false);
xhr.send();
document.write("hi");
</script>
</div>
</body>
</html>
发布于 2014-07-24 15:23:30
XMLHttpRequest
可以用作同步和异步,第三个参数传递给函数设置这个模式。传递false
意味着设置为同步,例如等待调用完成
改为:
var xhr = new XMLHttpRequest();
xhr.open("GET","http://www.google.com",true);
xhr.send();
document.write("hi");
它应该写出"hi"
,或者您可以完全删除第三个参数,它默认为异步。
var xhr = new XMLHttpRequest();
xhr.open("GET","http://www.google.com");
xhr.send();
document.write("hi");
发布于 2014-07-24 15:23:13
您不能向http://www.google.com
发出XHR请求,因为它是一个不同的来源。如果打开开发控制台,很可能会看到这样的错误:
Uncaught NetworkError: Failed to execute 'send' on 'XMLHttpRequest':
Failed to load 'http://www.google.com/'.
为了发出AJAX请求,所请求的域、端口和协议必须与原点匹配。
因为您的脚本的这一行正在抛出一个错误,并且调用被设置为非异步的(如LIUFA所述),下一行将不会被执行。
https://stackoverflow.com/questions/24937733
复制相似问题