• Flask WTForm表单的使用


    运行环境:

    python2.7

    flask  0.11

    flask-wtf  0.14.2

    wtform能够通过一个类定义一些字段,这些字段会在前端生成标签,并且通过设置字段的验证规则,自动判断前端输入数据的格式。

    一般用于用户登录,用户注册等信息录入。

     1 from wtforms import Form
     2 from flask import Flask,render_template,request,redirect
     3 from wtforms.fields import core
     4 from wtforms.fields import html5
     5 from wtforms.fields import  simple
     6 from wtforms import validators
     7 from wtforms import widgets
     8 import sys
     9 reload(sys)
    10 sys.setdefaultencoding('utf8')
    11 #python2.7 转码用的,避免显示中文为乱码
    12 
    13 
    14 app = Flask(__name__,template_folder='templates')
    15 app.debug=True
    16 
    17 class LoginForm(Form):
    18     name = simple.StringField(
    19         label='用户名',   #前端显示中文
    20         validators=[
    21             validators.DataRequired(message='用户名不能为空'),
    22             validators.Length(min=6,max=18,message='用户名长度必须大于%(min)d且小于%(max)d')
    23         ],    #字段的验证规则
    24         widget=widgets.TextInput(), #页面上显示的标签
    25         render_kw={'class':'form=control'} #给上面插件生成的时候添加属性,比如bootstrap的属性
    26     )
    27     pwd = simple.PasswordField(
    28         label='密码',
    29         validators=[
    30             validators.DataRequired(message='密码不能为空'),
    31             validators.Length(min=8,message='用户名长度必须大于%(min)d'),
    32             validators.Regexp(regex="^(?=.*[a-z])(?=.*[A-Z])(?=.*d)(?=.*[$@$!%*?&])[A-Za-zd$@$!%*/&]{8,}",
    33                               message='密码至少8个字符,至少1个大写字母,1个小写字母'),
    34 
    35         ],
    36         widget=widgets.PasswordInput(),
    37         render_kw={'class':'from-control'}
    38     )
    39 #字段,内部包含正则表达式
    40 
    41 @app.route('/login',methods=['GET','POST'])
    42 def login():
    43     if request.method == 'GET':
    44         form = LoginForm()
    45         return render_template('login.html',form=form)
    46         #将form对象传给前端
    47     else:
    48         form = LoginForm(formdata=request.form)  #从请求体from中取值
    49         if form.validate():   #验证
    50             print "用户提交数据通过,提交的值为:",form.data
    51         else:
    52             print form.errors    #错误信息
    53         return render_template('login.html',form=form)
    54 
    55 
    56 
    57 @app.route('/')
    58 def hello_world():
    59     return 'Hello World!'
    60 
    61 
    62 if __name__ == '__main__':
    63     app.run()
     1 <!DOCTYPE html>
     2 <html lang="en">
     3 <head>
     4     <meta charset="UTF-8">
     5     <meta http-equiv="x-ua-compatible" content="IE=edge">
     6     <meta name="viewport" content="width=device-width, initial-scale=1">
     7     <title>Title</title>
     8 </head>
     9 <body>
    10 <h1>登陆</h1>
    11 <form method="post">
    12     <p>{{ form.name.label }}  {{ form.name }} {{ form.name.errors[0] }}</p>
    13     <p>{{ form.pwd.label }}  {{ form.pwd }} {{ form.pwd.errors[0] }}</p>
    14     <input type="submit" value="提交">
    15 </form>
    16 </body>
    17 </html>

    在前端,直接通过Form对象来取字段中的值,以及该值中的错误信息,错误信息我们一般取第一个即可,已经能够告诉用户信息错误了。

  • 相关阅读:
    Java基础回顾 —内部类
    JAVA设计模式之观察者模式
    Java基础回顾 —注解
    JAVA设计模式之代理模式
    Java基础回顾 —反射机制
    JAVA设计模式之策略模式
    Java基础回顾 —String常量池
    JAVA设计模式之单例模式
    Java基础回顾 —抽象类、接口、多态
    Git的简单应用
  • 原文地址:https://www.cnblogs.com/ArmoredTitan/p/9005864.html
Copyright © 2020-2023  润新知