首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >烧瓶:如何在处理表单输入后更新div

烧瓶:如何在处理表单输入后更新div
EN

Stack Overflow用户
提问于 2018-09-15 10:27:47
回答 1查看 5K关注 0票数 1

我的Flask应用程序根据用户表单输入进行计算。这些计算大约需要10秒才能完成。这些计算的输出需要显示在同一页的div中,在表单旁边(图表/表等)。

我已经试过两次了。第一种是使用普通的烧瓶,重新加载整个页面,这是远远不理想的。第二种方法,使用Sijax,只更新div。但在这种情况下,我不知道如何访问表单输入。

我搞不懂怎么才能做到这点。任何方向都会感激的!

方法1:只需烧瓶(缺点:整个页面重新加载)

form_test.html

代码语言:javascript
复制
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Testpage</title>
</head>
<body>
    <form  action="{{ url_for('do_the_math') }}" method="post">
        A = <input type="number" name="input_A">
        B = <input type="number" name="input_B">
        <input type="submit" value="Submit">
    </form>
<div id="destination_div">A + B = {{ result }}</div>
</body>
</html>

app_normal.py:

代码语言:javascript
复制
from flask import Flask, render_template, request
app = Flask(__name__)

@app.route("/")
def show_home():
    return render_template("form_test.html", result='unknown yet')

@app.route("/do_the_math", methods=['POST'])
def do_the_math():
    A = request.form.get('input_A')
    B = request.form.get('input_B')
    sum = float(A) + float(B)

    # reloads whole page
    return render_template("form_test.html", result=sum)

    # what i want: reload just update destination_div with new HTML
    # return render_template("#destination_div", "A + B = " + str(sum))

if __name__ == '__main__':
    app.run(debug=True)

方法2:使用Sijax (更新div,但如何访问表单输入)

form_test_sijax.html

代码语言:javascript
复制
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Testpage with sijax</title>
    <script type="text/javascript" src="/static/js/sijax/sijax.js"></script>
    <script src='http://cdnjs.cloudflare.com/ajax/libs/jquery/2.1.3/jquery.min.js'></script>
</head>
<body>
    <form method="post">
        A = <input type="number" name="input_A">
        B = <input type="number" name="input_B">
        <button type="button" onclick="Sijax.request('submit_form');">calc</button>
    </form>
<div id="destination_div">A + B = unknown</div>
</body>
</html>

app_sijax.py

代码语言:javascript
复制
from flask import Flask, render_template, g
import flask_sijax
import os

app = Flask(__name__)

# init sijax
app.config["SIJAX_STATIC_PATH"] = os.path.join('.', os.path.dirname(__file__), 'static/js/sijax/')
app.config["SIJAX_JSON_URI"] = '/static/js/sijax/json2.js'
flask_sijax.Sijax(app)


def submit_form_handler(obj_response):
    A = 5  # how do get to the values entered in the form?
    B = 3
    sum = A + B
    obj_response.html("#destination_div", "A + B = " + str(sum))


@flask_sijax.route(app, "/")
def show_home():
    result = 'unknown'
    if g.sijax.is_sijax_request:
        g.sijax.register_callback('submit_form', submit_form_handler)
        return g.sijax.process_request()
    return render_template("form_test_sijax.html")


if __name__ == '__main__':
    app.run(debug=True)
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-09-15 15:03:01

您可以使用ajaxjquery动态更新页面,而不必刷新页面:

在html文件中:

代码语言:javascript
复制
<html>
  <header>
     <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.1.1/jquery.min.js"></script>
  </header>
 <body>
    <div class='wrapper'>
      A = <input type="number" id="input_A">
      B = <input type="number" id="input_B">
      <button class='get_result'>Calculate</button>
      <div class='result'></div>
    </div>
 </body>
 <script>
    $(document).ready(function(){
      $('.wrapper').on('click', '.get_result', function(){
         var val1 = $("#input_A").val();
         var val2 = $("#input_B").val();
         $.ajax({
          url: "/calculate_result",
          type: "get",
          data: {val1: val1, val2:val2},
          success: function(response) {
            $(".result").html('<p>'+response.result.toString()+'</p>');
          },
         });
      });
    });
 </script>
</html>

然后,在主应用程序文件中,创建用于计算最终结果的路由:

代码语言:javascript
复制
@app.route('/calculate_result')
def calculate_result():
  a = int(flask.request.args.get('val1'))
  b = int(flask.request.args.get('val2'))
  return flask.jsonify({"result":a+b})
票数 9
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52343833

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档