繁体   English   中英

Flask 应用程序中的下拉框使用 WTForms 未更新

[英]Dropdown box in Flask App using WTForms not updating

我有一个带有客户页面和项目页面的 flask web 应用程序。 这是工作流程,也是出错的地方。 有什么想法我可能出错了吗?

  1. 查看客户页面
  2. 点击“添加客户”> 转到“add_customer”路线
  3. 添加客户信息并点击提交
  4. 客户页面已正确更新为最新的客户名称
  5. 查看项目页面
  6. 单击“添加项目”> 转到“add_project”路线
  7. 此页面有一个客户列表下拉框,但不包括我创建的最后一个客户或自上次启动 flask 以来我创建的任何客户。

如果我重新启动 flask,下拉框包含最新的客户。 起初我以为我没有提交数据库,但似乎我与下面的 db.session.commit 在一起。 我发布了相关代码,如果您想查看其他内容,请告诉我。

我似乎在 web 上找不到我的特殊问题,我发现的大部分内容都与填写下拉框本身有关,这确实有效。

forms.py:

class AddProjectForm(FlaskForm):
    projectname = StringField('Project Name', validators=[DataRequired()])
    customer_query = Customer.query.all()
    customers = []
    for c in customer_query:
        customers.append(c.customername)
    customers = SelectField('Customer', choices=customers, default=1)
    submit = SubmitField('Add Project')

路线.py:

@app.route('/add_customer', methods=['GET', 'POST'])
@login_required
def add_customer():
    customer = Customer.query.all()
    form = AddCustomerForm()
    if request.method == 'POST':
        customername = request.values.get('customername') 
        c = Customer(customername=customername)
        db.session.add(c)
        db.session.commit()
        return redirect(url_for('customer'))
    return render_template("add_customer.html", title='Add a Customer', form=form)

@app.route('/add_project', methods=['GET', 'POST'])
@login_required
def add_project():
    form = AddProjectForm()
    if request.method == 'POST':
        projectname = request.values.get('projectname') 
        customer = request.values.get('customers') 
        customer_id = Customer.query.filter_by(customername=customer).first().id
        project = Project(projectname=projectname,customer_id=customer_id)
        db.session.add(project)
        db.session.commit()
        return redirect(url_for('projects'))
    return render_template("add_project.html", title='Add a Project', form=form)

add_project.html

{% extends "base.html" %}

{% block content %}
    <h1>Add a Project</h1>
    <form action="" method="post">
        {{ form.hidden_tag() }}
        <p>
            {{ form.projectname.label }}<br>
            {{ form.projectname }}<br>
        </p>
        <p>
            {{ form.customers.label }}<br>
            {{ form.customers }}<br>
        </p>
        <p>
            {{ form.submit() }}
        </p>
    </form>
{% endblock %}

在这里找到了答案:

Flask WTF 表单未使用 sqlite3 数据库更新

我从表单中删除了客户列表人口并将其添加到视图中。 然后将客户列表传递给模板,并像这样更新模板。

add_project.html

        <select name="customer" id="customer">
        {% for customer in customers %}
            <option value="{{ customer }}">{{ customer }}</option>
        {% endfor %}
        </select>

现在它正在工作。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM