Flask-WTForms 简单使用
安装 wtforms 2.2.1
直接上代码:
app.py 文件:
from flask import Flask, render_template, request
from wtforms import Form, validators
from wtforms.fields import simple, core # form 字段设计
class RegForm(Form):
# simple 字段类型
# StringField 和 TextAreaField 都是字符串的意思,StringField支持的类型少于StringField
username = simple.StringField(
label="用户名",
validators=[ # validators -- 校验信息
validators.DataRequired(message="用户不能为空"), # DataRequired -- 当前的地方必须填写数据; message -- 错误信息
validators.length(min=4, max=8, message="用户名必须大于等于4小于等于8") # length -- 长度
],
render_kw={"class": "my_class"} # 添加 class
) password = simple.PasswordField(
label="密码",
validators=[
validators.DataRequired(message="密码不能为空"),
validators.length(min=6, max=16, message="密码必须大于等于6小于等于16")
],
render_kw={"class": "my_class"} # 添加 class
) repassword = simple.PasswordField(
label="重复密码",
validators=[
validators.DataRequired(message="重复密码不能为空"),
validators.EqualTo("password", message="两次密码不一致") # EqualTo("字段名称") 判断该字段是否等于"字段名称"中的值
]
) gender = core.SelectField( # 单选字段在核心模块(支持的类型多)中才有
label="性别",
choices=( # 选项
(1, "女"),
(2, "男")
),
default=2, # 默认值
coerce=int # 指定前端提交过来的选项的类型是数字还是字符串 下边有验证
) email = simple.StringField(
label="邮箱",
validators=[
validators.Email(message="不符合规定")
]
) hobby = core.SelectMultipleField( # 多选字段
label="爱好",
choices=(
("", "读书"),
("", "美食"),
("", "电影"),
("", "音乐"),
),
default=("", "", "", ""),
coerce=str # 指定前端提交过来的选项的类型是数字还是字符串 下边有验证
) app = Flask(__name__) # 实例化 app reg_form = RegForm() # form信息(对象)赋值给reg_form @app.route("/form_reg", methods=["GET", "POST"])
def reg():
if request.method == "GET":
return render_template("form_reg.html", reg_form=reg_form)
if request.method == "POST":
reg_form_data = RegForm(request.form) # 拿到前端传过来的数据(request.form),给RegForm进行校验
if reg_form_data.validate(): # 如果前段穿过来的数据通过校验
print(type(reg_form_data.data.get("gender"))) # <class 'int'>
print(reg_form_data.data.get("hobby")) # ['1', '2', '3', '4']
return " * {注册成功} * 愿世界和平,无病无灾"
else:
# 前端传过来的内容未通过校验,返回注册页面, 附带注册提交的错误数据和错误提示
return render_template("form_reg.html", reg_form=reg_form_data) if __name__ == '__main__':
app.run()
form_reg.html 文件:
<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta http-equiv="content-Type" charset="UTF-8">
<meta http-equiv="x-ua-compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>Title</title> <style>
.my_class{
width: 500px;
}
</style>
</head>
<body>
<h1>注册页面</h1>
<form action="" method="post" enctype="multipart/form-data" novalidate>
{% for field in reg_form %}
<p>{{ field.label }}: {{ field }} <span style="color: red">{{ field.errors.0 }}</span> </p>
{% endfor %} {# {{ reg_form.username.label }}: {{ reg_form.username }}{{ reg_form.username.errors.0 }}<br>#}
{# {{ reg_form.password.label }}: {{ reg_form.password }}{{ reg_form.password.errors[0] }}<br>#} <input type="submit" value="提交">
</form>
</body>
</html>
Flask-WTForms 简单使用的更多相关文章
- Flask的简单认识
Flask的简单认识 Flask是轻量级的框架,适用于简单的程序 与Django的比较: Django: 无socket,中间件,路由,视图(CBV,FBV),模板,ORM, cookie,sessi ...
- 使用Flask开发简单接口
作为测试人员,在工作或者学习的过程中,有时会没有可以调用的现成的接口,导致我们的代码没法调试跑通的情况. 这时,我们使用python中的web框架Flask就可以很方便的编写简单的接口,用于调用或调试 ...
- Flask wtforms实现简单的登录注册
目录结构 视图 # -*- coding:utf-8 -*- # Author : Niuli # Data : 2019-02-27 19:26 from flask import render_t ...
- flask wtforms组件详解
一.简介 在flask内部并没有提供全面的表单验证,所以当我们不借助第三方插件来处理时候代码会显得混乱,而官方推荐的一个表单验证插件就是wtforms.wtfroms是一个支持多种web框架的form ...
- Flask wtforms 表单验证使用
目录 wtforms 使用1(简单版): 使用2(复杂版): wtforms 安装:pip3 install wtforms 使用1(简单版): from flask import Flask, re ...
- Flask WTForms的使用和源码分析 —— (7)
Flask-WTF是简化了WTForms操作的一个第三方库.WTForms表单的两个主要功能是验证用户提交数据的合法性以及渲染模板.还有其它一些功能:CSRF保护, 文件上传等.安装方法: pip3 ...
- flask的简单使用
一.Flask中的CBV from flask import Flask, render_template from flask import views app = Flask(__name__, ...
- Python: Flask框架简单介绍
接触Python之后我第一次听说Flask,我就根据自己搜罗的知识尽可能简洁的说出来.如果不准确的地方还请指正,谢谢. Flask是什么? Flask是基于Python编写的微 ...
- WTForms In Flask(WTForms在Flask中的应用)
WTForms WTForms是一个支持多个web框架的form组件,主要用于对用户请求数据进行验证. 安装wtforms : pip3/pip install wtforms 用户登录/注册示例 项 ...
- Flask实现简单的群聊和单聊
Flask是使用python写的一个简单轻量级的框架,今天我们使用Flask实现一个简单的单聊和群聊功能 . 主要思路 : 前端登录聊天室,聊天室信息包含用户的登录信息,相当于一个登录功能,会把这个信 ...
随机推荐
- vs2008 点击"转到定义"为什么是"未定义符号"
1.有可能是VA未安装正确,但是我遇到的情况是我的VA安装正确的. 2.我的解决办法:删掉工程的.ncb文件后重新编译即可:以前也遇到过断点打不上去的事情,也是删掉.ncb后重新编译就可以了. 附带一 ...
- LeetCode 789. Escape The Ghosts
题目链接:https://leetcode.com/problems/escape-the-ghosts/description/ You are playing a simplified Pacma ...
- Ubuntu系统配置
0.基本配置 0.1初始设置 (1)开户root账号并重启系统: 打开gedit /usr/share/lightdm/lightdm.conf.d/50-ubuntu.conf 添加greeter- ...
- Vue 路由的模块化
其实就是对路由配置和实例化的过程进行js封装,挂载路由的时候依然在main.js中: 步骤: 1.在src文件夹下新建一个router文件夹,在router文件夹下新建文件router.js; 2.引 ...
- 观察者模式的python实现
什么会观察者模式?观察者模式就是订阅-推送模式.是为了解耦合才会被利用起来的设计模式. 经典的就是boss 前台和员工之间的故事.一天A员工在看电影,B员工在看动漫,但是两人担心boss来了,自己没及 ...
- git 入门与应用
git可视化界面的项目版本控制软件,适用于git项目管理 SourceTree 安装方法 https://blog.csdn.net/qq_26230421/article/details/79921 ...
- Java反射讲解
首先我们通过代码来看看发射的作用到底是什么. 1. 首先准备两个很简单的业务类 2. 非反射方式切换不同的业务方法调用 当需要从第一个业务方法切换到第二个业务方法的时候,使用非反射方式,必须修改代码, ...
- 201772020113李清华《面向对象程序设计(java)》第十二周学习总结
1.实验目的与要求 (1) 掌握Java GUI中框架创建及属性设置中常用类的API: (2) 掌握Java GUI中2D图形绘制常用类的API: (3) 了解Java GUI中2D图形中字体与颜色的 ...
- 搭建rancher节点
1.centos 7.5 64 2.安装docker systemctl restart docker.service 注意:重启后才有 /etc/docker/文件夹 切换到这文件夹下再增加对应的d ...
- NTP时间服务
时间服务 NTP:Network Time Protocol 作用:用来给其他主机提供时间同步服务 NTP的配置文件 /etc/ntp.conf NTP相关的命令 date:显示/修改系统时间 hwc ...