2014-01-18 61 views
3

我尝试使用Flask创建一个基本的会计包,我有点卡在验证特定的表单。它正在为同一个应用程序中的另一个表单工作,但出于某种原因,我无法弄清楚为什么这个工具不能正常工作。表单显示为它应该在网络浏览器中,我可以正常输入数据,但是当我提交表单时,它似乎只是重新加载页面。我的数据库没有得到更新,经过一些挖掘,我发现我的if form.validate_on_submit()没有捕捉任何东西。Flask WTForms表单没有提交,但输出没有验证错误

堆栈跟踪中也没有发生任何错误。

我将在下面发布我的文件的相关部分。

views.py

@app.route('/dashboard/<nickname>/work-orders/add/', methods = ['GET', 'POST']) 
@login_required 
def work_orders_add(nickname): 
ca = check_active(nickname) 
if ca[1] == True: 
    form = AddWorkOrderForm() 
    u = User.query.get(current_user.id) 
    c = u.contacts.order_by('name').all() 
    form.requestor.choices = [(contact, contact.name) for contact in c] 
    if form.validate_on_submit(): 
     db.session.add(WorkOrder(requestor = form.requestor.data, 
      date = form.date.data, 
      notes = form.notes.data, 
      total = 0.00, 
      completed = form.completed.data, 
      user = g.user)) 
     db.session.commit() 
     return redirect(url_for('work_orders', nickname=current_user.nickname)) 
    elif request.method != "POST": 
     form.date.data = datetime.date.today() 
    else: return "didn't work" 
    return render_template('work_orders_add.html', 
     user = ca[0], 
     title = "New Work Order", 
     form = form) 
else: return redirect(url_for('work_orders', nickname=current_user.nickname)) 

forms.py

class AddWorkOrderForm(Form) 
    requestor = SelectField('requestor', coerce=unicode) 
    date = DateField('date') 
    notes = TextAreaField('notes') 
    completed = BooleanField('completed', default = False) 

models.py

class WorkOrder(db.Model): 
    __tablename__ = 'workorder' 
    id = db.Column(db.Integer, primary_key = True) 
    date = db.Column(db.String(64)) 
    notes = db.Column(db.String(1024)) 
    total = db.Column(db.Float) 
    completed = db.Column(db.Boolean) 
    user_id = db.Column(db.Integer, db.ForeignKey('user.id')) 
    contact_id = db.Column(db.Integer, db.ForeignKey('contact.id')) 
    items = db.relationship('WorkOrderItem', primaryjoin="WorkOrder.id==WorkOrderItem.work_order_id", backref = 'order') 

    def __repr__(self): 
     return '<WorkOrder %r>' % (self.id) 

我的HTML文件:

{% extends "_is_logged.html" %} 
{% block content %} 
<h1>{{ title }}</h1> 
<form action="" method="post" name="work_order"> 
    {{ form.hidden_tag() }} 
    <p>Requestor: {{ form.requestor() }}</p> 
    <p>Date: {{ form.date() }}</p> 
    <p>Notes: {{ form.notes(size=70) }}</p> 
    <p>Completed: {{ form.completed() }}</p> 
    <p><input type="submit" value="Add Work Order"></p> 
</form> 
{% endblock %} 

谢谢。

+0

会发生什么事,如果你添加一个'{%FIELD_NAME的,在form.errors.items field_errors()%}

{{FIELD_NAME}}

    {%error for field_errors%}
  • {{error}}
  • {%endfor%}
{%endfor%}

'您的模板文件? –

+0

我曾尝试添加,但似乎没有改变。您的代码是否需要更改,但放入我的模板文件中?或者应该简单的复制和粘贴工作? – LJPPython

+0

不,它应该刚刚工作,只要你把它放在'内容'块... –

回答

0

我觉得@Iarissa早就发现了它。该表格没有行动值,作为第一步,我建议你改变这一点:

<form action="" method="post" name="work_order"> 

到:

<form action="{{url_for('work_orders_add')}}" method="POST" name="work_order"> 
从给定的代码

此外,它看起来像功能work_orders_add(nickname)似乎并不正确缩进。 if语句应包含在功能,这样你会:

@app.route('/dashboard/<nickname>/work-orders/add/', methods = ['GET', 'POST']) 
@login_required 
def work_orders_add(nickname): 
    ca = check_active(nickname) 
    if ca[1] == True: 
     form = AddWorkOrderForm() 
     u = User.query.get(current_user.id) 
     c = u.contacts.order_by('name').all() 
     form.requestor.choices = [(contact, contact.name) for contact in c] 
     if form.validate_on_submit():