【问题标题】:Python / Flask / WTForm / Jinja: Passing variable value into wftform field for "Update Page"Python / Flask / WTForm / Jinja:将变量值传递给“更新页面”的 wftform 字段
【发布时间】:2018-11-29 15:47:11
【问题描述】:

我将FlightNoTerminalStatus 保存到 MongoDB 中。我想创建一个更新页面,以便可以更新值。如何在 WTForm 字段中传递数据库中的现有值?

app.py:

# Document just for your info!
Document = { "_id" : ObjectId("5bfffb603129d742ac94b990"), "flightno" : "LH-100", "terminal" : "A1", "status" : "Inbound" }

@app.route("/update/<id>"):
def update(id):
     currFlight = db.find_one({"flightno": id})
     form = FlightForm()

     if request.method == "POST":
        f = session["flightno"] = form.flightno.data
        t = session["terminal"] = form.terminal.data
        s = session["status"] = form.status.data

        query = {"flightno": f}
        update = {"$set": {"flightno": f, "terminal": t, "status": s}}
        db.update(query, update)

        return redirect(url_for("index"))
     return render_template("update.html", currFlight=currFlight)

update.html:

<form method="POST">
   {{form.hidden_tag()}}
   {{form.flightno.label}} {{form.flightno}} <br>
   {{form.terminal.label}} {{form.terminal}} <br>
   {{form.status.label}} {{form.status}} <br>
   {{form.submit()}}
</form>

如何将currFlight 中的值传递到表单中,以便字段已经填充了currFlight 中的值? 我试过value="",虽然它只适用于StringFieldTerminalStatusSelectFields,所以它不起作用。

【问题讨论】:

    标签: python flask wtforms


    【解决方案1】:

    当表单方法为“POST”时,您正在从表单字段中读取值并将它们保存在数据库中。类似地,当表单方法为 GET 时,您可以从数据库中读取值并将它们传递给表单。请参阅下面的代码 -

    #after your if block
    elif request.method == "GET":
        form.flightno.data = currFlight.flightno
        form.terminal.data = currFlight.terminal
        form.status.data = currFlight.status
    

    当页面第一次加载时,方法将是 GET,并且表单字段将具有来自数据库的值。确保将表单传递给 html 模板,如下所示 -

    return render_template("update.html", currFlight=currFlight, form=form)
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2019-01-02
      • 2022-01-13
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2018-03-05
      • 1970-01-01
      相关资源
      最近更新 更多