表单

HTML表单

在HTML中,表单通过<form>标签创建,表单中的字段使用<input>标签定义:
在这里插入图片描述
渲染后效果:
在这里插入图片描述

使用Flask-WTF处理表单

先用Pipenv 安装Flask-WTF 及其依赖:

$ pipenv install flask-wtf

Flask-WTF 默认为每个表单启用csrf保护,它会为我们自动生成和验证csrf令牌. 我们需要为程序设置密钥:

app.secret key = 'secret string'
  • 定义WTForms表单类

    from flask_wtf import FlaskForm
    from wtforms import StringField, PasswordField, BooleanField, SubmitField
    from wtforms.validators import DataRequired, Length
    
    class LoginForm(FlaskForm):
    	username = StringField('Username', validators=[DataRequired()])
    	password = PasswordField('Password', validators=[DataRequired(), Length(8, 128)])
    	remember = BooleanField('Remember me')
    	submit = SubmitField('Log in')
    
  • 常用的WTForms字段

    在这里插入图片描述
    实例化字段类传入的参数:
    在这里插入图片描述
    常用的WTForms验证器:
    在这里插入图片描述

  • 输出HTML代码

    使用WTForms创建的LoginForm为例:

    >>> form = LoginForm()
    >>> form.username()
    '<input id="username" name="username" required type="text" value="">'
    

    字段的label值:

    >>> form.username.label()
    '<label for="username">Username</label>'
    

    在创建HTML表单时,我们经常需要使用HTML <input>元素的其他属性对字段进行设置. 比如 添加class属性、添加placeholder属性设置占位文本.
    添加额外属性方法:

    • 使用render_kw属性

      比如下面的username字段使用render_kw设置了placeholder HTML属性:
      username = StringField('Username', render_kw={'placeholder':'Your Username'})
      
      这个字段被调用后输出的HTML 代码如下所示:
      <input type ="text" id="username" name="username" placeholder="Your Username" >
      
    • 在html中添加

      	<div class="form-group">
              {{ form.username.label }}
              {{ form.username(class='form-control') }}
          </div>
      
  • 在模板中渲染表单

    为了能够在模板中渲染表单,我们需要把表单类实例传入模板.

    @app.route('/basic')
    def basic():
    	form = LoginForm()
    	return render_template('login.html', form=form)
    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值