flask form表单

首先安装第三方form表单的扩展包,当然不使用第三方的也可以。第三方包的功能更多。

一、安装扩展

pip install flask-wtf

二、创建一个form表单类

from flask_wtf import FlaskForm
from wtforms import StringField, PasswordField, SubmitField
from wtforms.validators import DataRequired, EqualTo, Length

class Register(FlaskForm):
    username = StringField(label='username',
                           validators=[DataRequired()],
                           render_kw={
                               'placeholder': 'username',
                               'class': 'input_text'
                           })
    password = PasswordField(label='password',
                             validators=[DataRequired(),
                                         Length(3, 8, '密码长度必须在3-8之间')])
    cpassword = PasswordField(label='cpassword',
                              validators=[DataRequired(),
                                          EqualTo('password', '两次密码不一致')])
    submit = SubmitField('提交')

前端会根据label生成id和name属性,validators会提供表单提交时的验证。render_kw可以添加额外的属性,例如,要个username 输入框添加提示和类属性,可以这样写

render_kw={
    'placeholder': 'username',
    'class': 'input_text'
}
常用验证类介绍

DataRequired()验证是否为空(不允许为空,空白字符视为空)
在这里插入图片描述
NumberRange(),验证数字范围
在这里插入图片描述
Length(),验证字符串长度
在这里插入图片描述
EqualTo(),比较两个值是否相同
在这里插入图片描述

三、使用表单

@app.route('/testform', methods=['get', 'post'])
def testform():
    form = Register()
    if request.method == 'GET':
        return render_template('form.html', form=form)
    if request.method == 'POST':
        # 验证表单
        if form.validate_on_submit():
            # 获取表单方式1
            username = form.username.data
            password = form.password.data
            print("11111111111111111111111111111")
            print(username)
            print(password)
            # 获取表单方式2
            print("22222222222222222222222")
            print(type(form.data))
            print(form.data)
            return "success"
        else:
            # 验证失败
            print(form.errors)
            error_msg = form.errors
            for k, v in error_msg.items():
                print(k, v[0])
            return "failed"

四、前端添加表单

<form action="/testform" method="post">
    {{ form.csrf_token }}
    {{ form.username.label }}{{ form.username }}
    {{ form.password.label }}{{ form.password }}
    {{ form.cpassword.label }}{{ form.cpassword }}
    {{ form.submit }}
</form>

前端页面
在这里插入图片描述
前端源代码
在这里插入图片描述

当使用 Flask 框架时,可以使用 Flask-WTF 扩展来创建表单。以下是一个简单的注册表单的示例: ```python from flask_wtf import FlaskForm from wtforms import StringField, PasswordField, SubmitField from wtforms.validators import DataRequired, Email, EqualTo class RegisterForm(FlaskForm): username = StringField('Username', validators=[DataRequired()]) email = StringField('Email', validators=[DataRequired(), Email()]) password = PasswordField('Password', validators=[DataRequired()]) confirm_password = PasswordField('Confirm Password', validators=[DataRequired(), EqualTo('password')]) submit = SubmitField('Sign Up') ``` 这个表单有四个字段:用户名、电子邮件、密码和确认密码。每个字段都有一个标签和一组验证器,例如 `DataRequired()` 验证器确保该字段不为空,`Email()` 验证器确保输入的值是有效的电子邮件地址,`EqualTo('password')` 验证器确保确认密码与密码相同。 在视图函数中,可以通过 `request.form` 来获取表单数据,如下所示: ```python from flask import render_template, redirect, url_for, flash, request from yourapp import app from yourapp.forms import RegisterForm @app.route('/register', methods=['GET', 'POST']) def register(): form = RegisterForm() if form.validate_on_submit(): # 处理表单提交 flash('Thanks for registering!') return redirect(url_for('index')) return render_template('register.html', form=form) ``` 在这个示例中,`form.validate_on_submit()` 方法检查表单是否已被提交并且通过了所有的验证器。如果表单数据有效,视图函数将执行处理提交的代码。否则,它将渲染包含表单的模板,以便用户可以重新输入有效的数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值