这是一个非常简单的问题,但我似乎找不到一个好的答案。
我存储了有关用户选择的现有数据,并希望将该选择呈现为下拉列表中的选择。
{% macro render_bootstrap_field(field) %}
<div class="form-group {% if field.errors %} error {% endif %}">
<label class="col-lg-2 control-label">{{ field.label }}</label>
<div class="col-lg-8">
{{ field(class='form-control')|safe }}
{% if field.errors %}
{% for error in field.errors %}
<span class="help-inline">[{{ error }}]</span><br>
{% endfor %}
{% endif %}
</div>
</div>
{% endmacro %}}
这是如何呈现的:
{{ render_bootstrap_field(form.gender) }}
它没有显示选择的内容,除了使用 jquery 手动添加类之外,我想不出其他方法,但这会很痛苦。
非常感谢你的帮忙!
编辑:忘记包含我的 view.py 函数!所以我确实设置了它
@app.route('/edit_user', methods=['GET', 'POST'])
@login_required
def edit_user():
form = UserInfoForm(g.user.nickname)
form.gender.choices = app.config['GENDER']
form.year.choices = app.config['BIRTH_YEAR']
form.education.choices = app.config['EDUCATION']
if request.method == 'POST' and form.validate_on_submit():
flash("submitting")
g.user.nickname = form.nickname.data
g.user.gender = form.gender.data
g.user.education = form.education.data
g.user.year = form.year.data
g.user.info_complete = True
db.session.add(g.user)
db.session.commit()
return redirect(url_for('edit_user'))
elif request.method != "POST":
form.nickname.data = g.user.nickname
form.gender.data = g.user.gender
form.education.data = g.user.education
form.year.data = g.user.year
return render_template('edit_user.html',
form=form,
user=g.user)
发现问题!
如果您遇到同样的问题 --- 检查您的编码!我的 unicode 正在抛出正常的字符串。