7

我正在使用 Flask 编写一个 Web 应用程序,并且想在 Brython 中使用 browser.ajax 功能,但找不到可行的示例。如果有人演示一个如何在 Brython 中使用 ajax 的简短示例,那就太好了。更具体地说,如何通过单击提交按钮将用户输入到文本字段中的数据传递到文本区域。非常感谢任何帮助!


(在我发布上述问题几周后,我正在写这篇文章)。我按照本教程介绍了如何在 Flask 中实现 ajax(http://runnable.com/UiPhLHanceFYAAAP/how-to-perform-ajax-in-flask-for-python)并尝试用 Brython 替换 jquery.ajax。不幸的是,我仍然无法让它工作。这是我的代码:

Flask的部分:

@app.route('/')
def index():
    return render_template('index.html')

@app.route('/_add_numbers')
def add_numbers():
    a = request.args.get('a', 0, type=int)
    b = request.args.get('b', 0, type=int)
    return jsonify(result=a + b)

布莱顿/HTML:

 <body onload="brython()">
 <script type="text/python">
 from browser import document as doc
 from browser import ajax

def on_complete(req):
    if req.status==200 or req.status==0:
        doc["txt_area"].html = req.text
    else:
        doc["txt_area"].html = "error "+req.text

def get(url):        
    req = ajax.ajax()
    a = doc['A'].value        
    b = doc['B'].value
    req.bind('complete',on_complete)
    req.open('GET',url,True)
    req.set_header('content-type','application/x-www-form-urlencoded')
    req.send({"a": a, "b":b})      

doc['calculate'].bind('click',lambda ev:get('/_add_numbers'))

</script>

<div class="container">
  <div class="header">
    <h3 class="text-muted">How To Manage JSON Requests</h3>
  </div>
  <hr/>
  <div>
  <p>
<input type="text" id="A" size="5" name="a"> +
<input type="text" id ="B" size="5" name="b"> =
<textarea type="number" class="form-control" id="txt_area" cols="10" rows = '10'></textarea>
<p><a href="javascript:void();" id="calculate">calculate server side</a>

  </div>
 </div>
 </body>
</html>

我得到的是“结果”:0。看起来 brython 没有将数据发送到 Flask 的视图函数,但我不知道如何解决这个问题。所以,如果有人能指出我到底做错了什么,那就太好了。

4

2 回答 2

6

在您的示例中,Ajax 请求是使用 GET 方法发送的。在这种情况下,send() 的参数被忽略:数据必须在附加到 url 的查询字符串中发送

Brython 代码应该是:

def get(url):        
    req = ajax.ajax()
    a = doc['A'].value        
    b = doc['B'].value
    req.bind('complete',on_complete)
    # pass the arguments in the query string
    req.open('GET',url+"?a=%s&b=%s" %(a, b),True)
    req.set_header('content-type','application/x-www-form-urlencoded')
    req.send()

如果你想使用 POST 方法,那么你可以保持 Brython 代码原样,但 Flask 代码应该修改:你必须指定函数处理 POST 请求,并且你得到带有属性“form”的参数“参数”:

@app.route('/_add_numbers_post', methods=['POST'])
def add_numbers_post():
    a = request.form.get('a', 0, type=int)
    b = request.form.get('b', 0, type=int)
    return jsonify(result = a+b)
于 2014-12-02T10:44:16.670 回答
3

我正在努力解决这个问题——没有任何现成的东西,但是编写 Python 代码让它变得非常轻松。

我无法发布我正在处理的代码,(而且它远非最小) - 但基本上,您编写一个 (Br)Python 函数来迭代 HTML 或formDOM,并收集所有具有“价值”的东西在 json-nish 结构中(带有嵌套字典和列表的字典) - 您只需使用http://brython.info/doc/en/index.html#中记录的 browser.ajax 对象,然后传递将您的数据作为“发送”方法的参数的对象。

对象数据将在请求正文中进行 URL 编码。您只需将其从那里解码为客户端的 JSON。

作为一个额外的提示:我没有深入探讨这个问题,但我觉得默认使用的 URLencoding 可能无法表达 JSON 中可能的所有内容。所以导入了 brython 的 json 模块,并像这样发送:

ajax_object.send({"data": json.dumps(json_data)})

这使我可以在客户端执行此操作: json_data = json.loads(urllib.unquote(request.body).split(":",1)[-1] )

(“request.body”来自 Pyramid - 对于烧瓶,它是“request.data”,但前提是烧瓶不理解 conte 类型 - 检查如何获取在 Flask 请求中收到的数据

于 2014-11-25T16:47:00.707 回答