簡體   English   中英

燒瓶WTForm驗證對SelectField失敗...為什么?

[英]Flask WTForm validation failing for SelectField…why?

我正在使用Flask和WTForm制作一個Web應用程序,到目前為止,我的其他兩個字段都可以很好地驗證,但是SelectField拋出錯誤“請選擇一只寵物”。 正如我自己指定的,即認為自己沒有收到有效的輸入。 SelectField.choices與呈現為HTML的選項匹配,所以我在做什么錯呢?

app.py

from flask_wtf import Form
from flask_wtf.csrf import CSRFProtect
from wtforms import IntegerField, StringField, SelectField, validators, 
ValidationError
from flask import Flask, request, flash, render_template

app = Flask(__name__)
app.secret_key = 'xxxxxxxxxxxx'
csrf = CSRFProtect(app)


pChoices = [('-1', '-----'),
            ('0', 'Cat'),
            ('1', 'Dog'),
            ('2', 'Parrot'),
            ('3', 'Hamster')]


class paymentForm(Form):
    productF = SelectField('productF', [validators.input_required("Please choose a pet.")], choices=[pChoices], coerce=int)
    buyer_id = StringField('buyer', [validators.input_required("Please enter your name.")])
    paid = DecimalField('paid', [validators.input_required("please enter payment amount")])


@app.route('/', methods=['POST', 'GET'])
def index():
    form = paymentForm(request.form, csrf_enabled=True)
    if form.validate_on_submit():
        flash('Order Placed Successfully', 'success')
        data = form.data
        record_order(data)
        print(data['price'])
        return render_template('confirmation.jinja',
                               pets=PETS,
                               title='Confirmation Page',
                               form=form, error=form.errors,
                               ** context)
    elif not form.validate_on_submit:
        flash('Submission error, please check the form', 'success')
    return render_template('index.jinja',
                               title='Order Form',
                               form=form,
                               error=form.errors,
                               **context)

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

index.jinja

{% extends 'base.jinja' %}

{% block main %}
  <form method="post">
    <div class="form-group row">
      <label for="product" class="col-sm-2 form-control-label">Pet:</label>
      <div class="col-sm-8">
        <select id="productF" class="form-control" name="pet" onchange="Update()">
          <option value="-1">-----</option>
          {% for pet in pets %}
            <option value="{{ loop.index -1 }}">{{ pet.name }}</option>
          {% endfor %}
        </select>
      </div>
    </div>
    <div class="form-group row">
      <label for="buyer" class="col-sm-2 form-control-label">Buyer:</label>
      {% for message in form.buyer_id.errors %}
         <div>{{ message }}</div>
      {% endfor %}
      <div class="col-sm-10">
        <input type="text" class="form-control" id="buyer_id" name="buyer_id" placeholder="Buyer" value="{{ buyer_id }}" required>
      </div>
    </div>
    <div class="form-group row">
      <label for="paid" class="col-sm-2 form-control-label">Amount Paid:</label>
      {% for message in form.paid.errors %}
         <div>{{ message }}</div>
      {% endfor %}
      <div class="col-sm-10">
        <input type="text" class="form-control" id="paid" name="paid" placeholder="Amount Paid" value="{{ paid }}" required>
      </div>
    </div>
    {% if form.errors %}
    {{ form.errors }}
    {% endif %}
    <div class="form-group row">
      <div class="col-sm-offset-2 col-sm-10">
        <button type="submit" class="btn btn-primary">Place Order</button>
      </div>
    </div>
        <input type="hidden" name="csrf_token" value="{{ csrf_token() 
}}"/>
  </form>


{% endblock %}

編輯我已使用productF作為jinja文件中的字段名稱更新了代碼,但仍然收到錯誤。 Pets對象作為JSON對象而不是app.py加載到HTML頁面中,但是據我所知,值是相同的。 這是檢查器中選擇元素的顯示方式:

<select id="product" class="form-control" name="product">
          <option value="-1">-----</option>         
            <option value="0">Cat</option>          
            <option value="1">Dog</option>          
            <option value="2">Parrot</option>          
            <option value="3">Hamster</option>          
        </select>

您正在將pChoices定義為列表

pChoices = [('-1', '-----'),
            ('0', 'Cat'),
            ('1', 'Dog'),
            ('2', 'Parrot'),
            ('3', 'Hamster')]

但是,然后將其包裝在SelectField定義的另一個列表中:

productF = SelectField(..., choices=[pChoices], ...)

使用choices=pChoices應該修復它。

編輯:您也有pet作為表單jinja模板中的字段名稱,您可能要使用productF

編輯2:定義pChoices和字段強制的值的方式不匹配。 從表單字段中刪除coerce=int或將pChoices中的元組的第一個值設置為整數,而不是字符串。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM