如何使一个POST与ajax就像表单提交

How to make a POST with ajax just like the form submit?

本文关键字:表单提交 ajax 何使一 POST      更新时间:2023-09-26

我试图发送POST请求到我的python(谷歌应用引擎)服务器使用Ajax就像我们从表单提交,但它不工作。

这是我的HTML:
<!DOCTYPE html>
<html>
 <head>
 <title>Test</title>
 <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.5.2/jquery.min.js" type="text/javascript"></script>
</head>
<body>
  <button>apple</button>
  <form method="POST" action="/">
  <input name="url" value="value1" id="urlimg">
  <br>
  <input class="myButton" type="submit" value="FIND OUT" id="submit_button">
  </form>
  <script type="text/javascript">
     $(document).ready(function(){
       $('button').click(function() {
          $.post('/', { url: 'value1'});
       });
    });
  </script>
</body>
</html>  
这是我的python代码:
import os
import webapp2
import jinja2
import urllib2 as urllib
template_dir = os.path.join(os.path.dirname(__file__), '')
jinja_env = jinja2.Environment(loader = jinja2.FileSystemLoader(template_dir),
                           autoescape = True)
class Handler(webapp2.RequestHandler):
    def write(self,*a,**kw):
        self.response.write(*a,**kw)
    def render_str(self,template,**params):
        t = jinja_env.get_template(template)
        return t.render(params)
    def render(self,template,**kw):
        self.write(self.render_str(template,**kw))
class MainHandler(Handler):
    def get(self):
        self.render('image.html')
    def post(self):
        url = self.request.get('url')
        self.response.write(url + ' is your url')
app = webapp2.WSGIApplication([
('/', MainHandler)
], debug=True)

您应该以JSON对象的形式返回响应:

class MainHandler(Handler):
    def get(self):
        self.render('image.html')
    def post(self):
        import json
        url = self.request.get('url')
        response_dict = {
            'message': 'Yay, I did it!', 
            'url': url + ' is your url',
        } 
        self.response.headers['Content-Type'] = 'application/json'
        self.response.out.write(json.dumps(response_dict))

然后在你的模板中这样处理响应:

$("button").click(function(){
    $.post("/", { url: $('#urlimg').val()}, function(data, status){
        alert("message: " + data.message + "'nURL: " + data.url + "'nStatus: " + status);
    });
});