2016-03-18 115 views
1

想象我需要建立一個旅遊規劃的形式是這樣的:Flask&WTForms:如何使用多個提交按鈕創建表單?

Going from [_Picadily_Circus____] 
Going to [_Marylebone_____] 
(Starting by) (Arriving by) [5]:[30][pm] 

兩者(由開始)(由到達)的提交按鈕。這個例子是假的,顯示一個雙按鈕的用例,所以我們不討論可用性。

如何使用Flask和WTForms做到這一點?

如何查看實際按下了哪個按鈕?

回答

7

如果按下按鈕,表單的提交按鈕的數據值將爲True。有兩個提交按鈕和一個輸入字段,請參閱下面的非常簡單的示例。

from flask import Flask, render_template, flash 
from flask.ext.wtf import Form 
from wtforms import StringField, SubmitField 
from wtforms.validators import DataRequired 

app = Flask(__name__) 
app.config['DEBUG'] = True 
app.config['SECRET_KEY'] = 'well-secret-password' 


class MyForm(Form): 
    name = StringField(label='Name', validators=[DataRequired()]) 
    starting = SubmitField(label='Starting') 
    ending = SubmitField(label='Ending') 


@app.route('/', methods=['GET', 'POST']) 
def index(): 
    form = MyForm() 

    if form.validate_on_submit(): 
     print "Starting data Value : {value}".format(value=form.starting.data) 
     print "Ending data Value : {value}".format(value=form.ending.data) 
     flash(
      "You submitted name {name} via button {button}".format(
       name=form.name.data, 
       button="Starting" if form.starting.data else "Ending" 
      ) 
     ) 

     return render_template('index.html', form=form) 

    if form.errors: 
     for error_field, error_message in form.errors.iteritems(): 
      flash("Field : {field}; error : {error}".format(field=error_field, error=error_message)) 

    return render_template('index.html', form=form) 


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

這裏是模板index.html文件:

<!DOCTYPE html> 
<html lang="en"> 
<head> 
    <meta charset="UTF-8"> 
    <title>Title</title> 
</head> 
<body> 

    {% with messages = get_flashed_messages() %} 
     {% if messages %} 
     <ul class=flashes> 
     {% for message in messages %} 
      <li>{{ message }}</li> 
     {% endfor %} 
     </ul> 
     {% endif %} 
    {% endwith %} 

    <form method="POST" action="{{ url_for('index') }}"> 
     {{ form.csrf_token }} 

     {{ form.name.label }} {{ form.name(size=20) }} 
     <br><br> 
     {{ form.starting }} 
     {{ form.ending }} 

    </form> 
</body> 
</html> 
相關問題