0

我正在构建一个应用程序,它将在我的主页/索引页面上显示 year_from 和 year_to 下拉列表,并将在另一个页面上返回匹配结果。

所需流量: 向用户显示 2 个带有预填充数据的下拉菜单。用户在索引路径上选择年份范围。然后,该年份范围将查询数据库并返回列表路线上年份范围之间的所有结果。

我能够达到可以逐年查询我的数据库的地步,并将它们呈现在 flask-wtf 查询选择字段中。

问题: 我无法从索引页面中获取用户选择的字段并使用它们生成查询并在我的列表页面中返回结果。未传递用户选择的字段。

我错过了什么?

路线

from flask import render_template, flash, redirect, url_for, request
from app import app
from app.models import Listingyear
from app.forms import YearForm

@app.route('/', methods=['GET', 'POST'])
@app.route('/index')
def index():
    form = YearForm()
    if form.validate_on_submit():
        year_from = request.form.get(year_from_select)
        year_to = request.form.get(year_to_select)
        return redirect (url_for('listing'))
    return render_template('index.html', form=form) 

@app.route('/listing', methods=['GET', 'POST'])
def listing():
    return render_template('listing.html')

形式

from flask_wtf import FlaskForm
from wtforms import SubmitField, SelectField
from wtforms.validators import DataRequired
from wtforms_alchemy.fields import QuerySelectField
from app.models import Listingyear

def Listingyear_from_query(): #for query_factory, sort year ascending, will update later
    return Listingyear.query

def Listingyear_to_query(): #for query_factory, sort year descending, will update later
    return Listingyear.query

class YearForm(FlaskForm):
    year_from_select = QuerySelectField(query_factory=Listingyear_from_query, allow_blank=False, get_label='year', validators=[DataRequired()])
    year_to_select = QuerySelectField(query_factory=Listingyear_to_query, allow_blank=False, get_label='year', validators=[DataRequired()])
    submit = SubmitField('Search')

指数

{% extends "base.html" %}

{% block content %}
<h1>My App</h1>
<form action="{{ url_for('listing') }}" method="post">
    {{ form.hidden_tag() }}
    {{ form.year_from_select }}
    {{ form.year_to_select }}
    <p>{{ form.submit() }}</p>
</form>
{% endblock %}
4

1 回答 1

0

https://stackoverflow.com/a/42708439/12472958

这解决了这个问题,它简单地展示了如何获取用户输入的值并将其传递给另一个路由。

于 2020-03-10T05:12:34.807 回答