XHR responseText 是空字符串

XHR responseText is empty string(XHR responseText 是空字符串)
本文介绍了XHR responseText 是空字符串的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

HTML页面:

<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>xhr</title>
</head>
<body>
    <script>
        var xhr_test = new XMLHttpRequest();
        xhr_test.open("GET","xhrtest",true);
        xhr_test.send();
        alert(xhr_test.responseText);
    </script>
</body>
</html>

main.py 文件:

The main.py file:

import webapp2
from handlers import cookies,pages
application = webapp2.WSGIApplication([
        ('/xhr',pages.XHR),
        ('/xhrtest', cookies.XHRTest)
        ],
            debug=True)

请求处理程序:

class XHRTest(webapp2.RequestHandler):
    def get(self):
        self.response.write('0')

和,

class XHR(webapp2.RequestHandler):
    def get(self):
        f = open('static/html/xhr.html','r')
        self.response.write(f.read())

现在,当我点击 URL localhost:8080/xhrtest 时,浏览器会立即将响应 0 显示为页面内容.

Now, when I hit upon the url localhost:8080/xhrtest the browser promptly shows the response 0 as the page's content.

点击url localhost:8080/xhr间接点击/xhrtest,在alert框中弹出一个空字符串(responseText是一个空字符串)但是检查在network标签下chrome的response标签,可以看到请求的响应是0.

Hitting the url localhost:8080/xhr which indirectly hits /xhrtest, pops up an empty string in the alert box (the responseText is an empty string) but checking chrome's response tab under the network tab, I can see that the request's response is 0.

那么为什么 xhr_test.responseText 不能显示相同的响应?

So why is xhr_test.responseText not able to display the same response?

推荐答案

send 调用是异步的(您已将 'async' 参数设置为 true),这意味着您的警报会在请求完成之前立即发生.您应该向 xhr.onreadystatechange 添加一个事件侦听器并在其中使用响应.

The call to send is asynchronous (you've set the 'async' parameter to true), which means that your alert is happening immediately, before the request finishes. You should add an event-listener to xhr.onreadystatechange and use the response within that.

将true"更改为false"可以使这个简单的示例工作,但在一般情况下不是一个好主意.

Changing the 'true' to 'false' would make this simple example work, but is not a good idea in the general case.

Ajax 上的 MDN 页面解释了如何使用 XMLHttpRequest.

The MDN page on Ajax explains how XMLHttpRequest should be used.

这篇关于XHR responseText 是空字符串的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Update another component when Formik form changes(当Formik表单更改时更新另一个组件)
Formik validation isSubmitting / isValidating not getting set to true(Formik验证正在提交/isValiating未设置为True)
React Validation Max Range Using Formik(使用Formik的Reaction验证最大范围)
Validation using Yup to check string or number length(使用YUP检查字符串或数字长度的验证)
Updating initialValues prop on Formik Form does not update input value(更新Formik表单上的初始值属性不会更新输入值)
password validation with yup and formik(使用YUP和Formick进行密码验证)