開發 Web 功能時,處理表單提交至關重要。為了在 Flask 中促進此過程,您可能會在檢索提交的表單值時遇到問題。本文重點介紹如何從 HTML 表單提交值並在 Flask 視圖中存取它們。
考慮以下HTML 表單:
<code class="html"><form method="POST"> <input id="my_input" type="text" value="{{ email }}"> <input id="my_submit" type="submit" value="Submit"> </form></code>
和對應的Flask路由:
<code class="python">@app.route('/page', methods=['POST', 'GET']) def get_page(): if request.method == 'POST': print(request.form) # prints ImmutableMultiDict([]) print(request.form['my_input']) # raises 400 error return render_template('page.html')</code>
提交表單時,你可能會發現request.form為空。嘗試直接檢索 my_input 的值會導致 400 錯誤。
問題的癥結在於輸入欄位中缺少 name 屬性。為了讓 Flask 正確處理表單,每個輸入都應該有一個與 request.form 中所需鍵相對應的 name 屬性。在這種情況下,以下修改應該可以解決問題:
<code class="html"><input name="my_input" id="my_input" type="text" value="{{ email }}"></code>
透過新增 name 屬性,輸入值將以「my_input」鍵提交到伺服器。因此,您可以在 Flask 視圖中無縫檢索值。
以上是如何在 Flask 中檢索提交的表單值:為什麼 request.form 為空?的詳細內容。更多資訊請關注PHP中文網其他相關文章!