【问题标题】:Sending response to ajax using tornado使用龙卷风向 ajax 发送响应
【发布时间】:2013-09-09 06:06:49
【问题描述】:

我有一个网络表单,它向包含表单数据的龙卷风服务器发送 ajax 发布请求,但响应由

self.write(message)

只是显示在浏览器中,而不是 js 处理它。我该如何纠正这个问题?

class NewHandler(BaseHandler):
@tornado.web.authenticated
def post(self):
    message = {
            "id": str(uuid.uuid4()),
            "from": self.current_user["name"],
            "body": self.get_argument("body"),
            }

    message["html"] = tornado.escape.to_basestring(self.render_string("message.html", message=message))
    self.write(message)
    messages.new([message])

js代码:

$(document).ready(function() {
document.session = $('#session').val();


$('#messageform').submit(function(event) {
    var formdata = $('#messageform').formData();
    var button = $('#messageform').find("input[type=submit]");
    button.prop("disabled", true);
    jQuery.ajax({
        url: '/new',
        type: 'POST',
        data: formdata,
        success: function(response){
            messageBox.show(eval("("+response+")");
            button.prop("disabled", false);
        }
    });
};

var messageBox = {
show: function(message){
    var content = $(message.html);

    $("#inbox").append(content);

}

【问题讨论】:

  • 尝试调用 event.preventDefault();就在 var formdata = $('#messageform').formData(); 之前

标签: jquery python ajax tornado


【解决方案1】:

尝试在 self.write() 方法之后引发 StopIteration:

self.write(somedata)
raise StopIteration

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2010-12-10
    • 1970-01-01
    • 1970-01-01
    • 2017-04-15
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多