javascript 简单的 Python 和 Ajax 示例 如何使用 Python 发送响应?

声明:本页面是StackOverFlow热门问题的中英对照翻译,遵循CC BY-SA 4.0协议,如果您需要使用它,必须同样遵循CC BY-SA许可,注明原文地址和作者信息,同时你必须将它归于原作者(不是我):StackOverFlow 原文地址: http://stackoverflow.com/questions/17843068/
Warning: these are provided under cc-by-sa 4.0 license. You are free to use/share it, But you must attribute it to the original authors (not me): StackOverFlow

提示:将鼠标放在中文语句上可以显示对应的英文。显示中英文
时间:2020-10-27 09:49:36  来源:igfitidea点击:

Simple Python and Ajax Example How to Send Response with Python?

javascriptpythonajaxwebapp2

提问by clifgray

I am testing out some code with Python and Javascript trying to get an Ajax system set up. Basically I just want to input a word and have the python code send it back. Here is my html/javascript:

我正在使用 Python 和 Javascript 测试一些代码,试图设置 Ajax 系统。基本上我只想输入一个单词并让python代码将其发回。这是我的 html/javascript:

<html>
<head>
<title>Simple Ajax Example</title>
<script language="Javascript">
function xmlhttpPost(strURL) {
    var xmlHttpReq = false;
    var self = this;
    // Mozilla/Safari/Chrome
    if (window.XMLHttpRequest) {
        self.xmlHttpReq = new XMLHttpRequest();
    }
    // IE
    else if (window.ActiveXObject) {
        self.xmlHttpReq = new ActiveXObject("Microsoft.XMLHTTP");
    }
    self.xmlHttpReq.open('POST', strURL, true);
    self.xmlHttpReq.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
    self.xmlHttpReq.onreadystatechange = function() {
        if (self.xmlHttpReq.readyState == 4) {
            updatepage(self.xmlHttpReq.responseText);
        }
    }
    self.xmlHttpReq.send(getquerystring());
}

function getquerystring() {
    var form     = document.forms['f1'];
    var word = form.word.value;
    qstr = 'w=' + escape(word);  // NOTE: no '?' before querystring
    return qstr;
}

function updatepage(str){
    document.getElementById("result").innerHTML = str;
}
</script>
</head>

<body>

<form name="f1">
  <p>word: <input name="word" type="text">  
  <input value="Go" type="button" onclick='JavaScript:xmlhttpPost("/ajaxtest")'></p>
  <div id="result"></div>
</form>

</body>

</html>

and here is my python:

这是我的蟒蛇:

class AjaxTest(BlogHandler):
    def get(self):
        user = self.get_user()       
        self.render('ajaxtest.html', user = user)
    def post(self):
        user = self.get_user()
        word = self.request.get('w')
        logging.info(word)
        return '<p>The secret word is' + word + '<p>'
        #having print instead of return didn't do anything

When I do logging the word shows up correctly and when I hardcode str in:

当我做记录时,这个词正确显示,当我硬编码 str 时:

function updatepage(str){
    document.getElementById("result").innerHTML = str;
}

It displays that correctly but right now without hardcoding it shows nothing. How am I supposed to send the response? I am using webapp2 as my Python framework and Jinja2 as the templating engine, though I don't think that has much to do with it. Do I need to send the HTTP headers?

它正确显示,但现在没有硬编码它什么也不显示。我应该如何发送响应?我使用 webapp2 作为我的 Python 框架,使用 Jinja2 作为模板引擎,尽管我认为这与它没有太大关系。我需要发送 HTTP 标头吗?

采纳答案by dm03514

If your problem is having difficulty returning a string from your post method, without rendering a template you can use the writemethod to accomplish that:

如果您的问题是难以从 post 方法返回字符串,而无需渲染模板,您可以使用该write方法来实现:

self.response.write('')

self.response.write('')

I believe you can change headers by just modifying self.response.headers

我相信您可以通过修改来更改标题self.response.headers