Flask——表单类

详细文档
使用例子:

from flask import Flask,redirect,url_for,render_template,session,flash
from flask_bootstrap import Bootstrap
from flask_wtf import FlaskForm
from wtforms import StringField,SubmitField
from wtforms.validators import Required

app=Flask(__name__)
bootstrap=Bootstrap(app)
app.config['SECRET_KEY']='huu cool'

#表示一个<form>表单,类变量表示表单的元素
class NameForm(FlaskForm):
#vilators可以指定验证函数组成的列表
    name=StringField('你叫什么名字?',validators=[Required()])
    submit=SubmitField('告诉我')

@app.route('/',methods=['POST','GET'])
def index():
    form=NameForm()
    if form.validate_on_submit():
        old_name=session.get('name')
        if old_name is not None and old_name != form.name.data:
            flash('Look like you have changed your name')
        session['name']=form.name.data
        return redirect(url_for('index'))
    return render_template('index.html',form=form,name=session.get('name'))

if __name__ == '__main__':
    app.run()

渲染表单的模板:

#templates/index.html#

{% extends "bootstrap/base.html" %}
{% import "bootstrap/wtf.html" as wtf %}
{% block title%} Hello {% endblock %}
{%block content%}
<div class="container">
    {%if name%}Hello {{name}} ! {%else%} Hello Stranger! {%endif%}
    #flash信息显示
     {% for message in get_flashed_messages() %}
    <div class="alert alert-warning">
    <button type="button" class="close" data-dismiss="alert">&times;</button>{{message}}     
    </div>
    {% endfor %}

    #flask_bootstrap快速渲染
    {{wtf.quick_form(form)}}
    #手动渲染  
    <!-- <form  method="POST">
    {{form.hidden_tag()}}
    {{form.name.label}}{{form.name()}}
    {{form.submit()}}
    </form> -->
</div>
{%endblock%}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值