# encoding=utf-8
from app.models import Student
from flask import g import re
from flask.ext.wtf import Form
from wtforms import StringField, RadioField, PasswordField, TextAreaField, BooleanField, DateField, ValidationError, \
IntegerField
from wtforms.validators import DataRequired, Length, Regexp, Email, EqualTo
from wtforms.widgets import ListWidget, HTMLString class BSListWidget(ListWidget):
def __call__(self, field, **kwargs):
kwargs.setdefault('id', field.id)
html = ""
for subfield in field:
html += u'<label class="radio-inline"> %s%s </label>' % (subfield(), subfield.label.text)
return HTMLString(html) class Fields(object):
notnull = u'该项输入不能为空' def get_len_str(min=None, max=None):
if min and not max:
return u"该项输入的最小长度必须是%d" % min
elif max and not min:
return u"该项输入的最大长度必须是%d" % max
else:
return u'该输入的长度必须大于%d,小于%d' % (min, max) username = StringField(label=u'请输入您的用户名',
validators=[DataRequired(message=notnull),
Length(min=0, max=15, message=get_len_str(0, 16)),
]) password = PasswordField(label=u'请输入密码', description=u'请输入密码',
validators=[DataRequired(message=notnull),
Length(min=0, max=60, message=get_len_str(min=0, max=61)),
])
confirm_password = PasswordField(label=u'请确认密码',
description=u'请确认密码', validators=[DataRequired(message=notnull),
Length(min=5, max=60, message=get_len_str(min=4, max=61)),
EqualTo(u'confirm_password', message=u'两次输入的密码不一致'), ]
)
student_amount = StringField(label=u'请输入您指导的学生数量',
validators=[Regexp(re.compile(r"\d"))]) is_active = RadioField(label=u'是否激活账户',
coerce=int,
choices=[(0, u'否'), (1, u'是')],
default=0,
widget=BSListWidget()) notice = TextAreaField(label=u'请填写对学生的通知') attachment = StringField(label=u'添加附加',
validators=[Length(min=0, max=32, message=get_len_str(min=0, max=33))], ) is_comment_teacher = RadioField(label=u'是否有评价功能',
coerce=int,
choices=[(0, u'否'), (1, u'是')],
default=0,
widget=BSListWidget()) student_name = StringField(label=u'请输入您的姓名',
description='',
validators=[DataRequired(message=notnull),
Length(min=0, max=15, message=get_len_str(0, 16)),
]) sex = RadioField(label=u'您的性别',
coerce=int,
choices=[(0, u'男'), (1, u'女')],
default=0,
widget=BSListWidget()) user_type = RadioField(label=u'您是',
coerce=str,
choices=[(u'student', u'学生'), (u'teacher', u'老师'), (u'admin', u'管理员')],
default=u'student',
widget=BSListWidget()) mark = StringField(label=u'您的分数',
default=0,
validators=[DataRequired(message=notnull),
Length(min=0, max=100, message=get_len_str(0, 101)),
])
comment = TextAreaField(label=u'请填写您对学生的评语',
validators=[
Length(min=0, max=128, message=get_len_str(0, 129)),
]) title = StringField(label=u'请填写毕业设计的题目',
validators=[
Length(min=0, max=128, message=get_len_str(0, 129)),
])
description = TextAreaField(label=u'请填写毕业设计的描述') task_start_date = DateField(label=u'开始时间')
task_end_date = DateField(label=u'结束时间') comment_start_date = DateField(label=u'开始时间')
comment_end_date = DateField(label=u'结束时间') class LoginForm(Form):
username = Fields.username
password = Fields.password user_type = Fields.user_type remember_me = BooleanField(label=u'记住我', default=u'y') errors = {} def validate_fields(self):
status = True
status = status and self.username.validate(self)
status = status and self.username.validate(self)
self.password.validate() # def validate(self):
self._fields
self.validate_on_submit()
return self.username.validate(self) # def validate_username(self, field):
# user = Student.get_user(field.data)
# if not user:
# print 'not user'
# self.errors['username'] = u'用户名不存在'
# raise ValidationError(message=u'该用户名已被注册')
# else:
# print 'user'
# return True #
# def validate_password(self,field):
# if g.user:
# if field.data != g.user.username:
# field.errors.append(message=u'用户密码不正确')
# return False
#
# def validate_user_type(self, field):
# print field.data
#
# def validate_remember_me(self,field):
# if field.data:
# print field.data class StuInfo(Form):
username = Fields.username
student_name = Fields.student_name
sex = Fields.sex
attachment = Fields.attachment
mark = Fields.mark
comment = Fields.comment class BaseForm(object):
def __init__(self, form):
self.username = Field(label=u'用户名', type='text', validators={'min_length': 5}) for field_name, data in form.items():
getattr(self, field_name).data = data def validate(self):
status = True
for field_name in self.__dict__:
status = status and getattr(self, field_name).validate()
return status class Field(object):
def __init__(self, label=None, type='text', validators={}, description=None, data=''):
self.data = data
self.label = label
self.type = type
self.validators = validators
self.description = description def validate(self):
status = True
for method_name, param in self.validators.items():
print method_name, param
status = status and getattr(self, method_name)(param)
return status def is_null(self, status):
if status:
return True
if not self.data:
return False
if hasattr(self.data, 'replace') and len(self.data.replace(' ', '')) > 0:
return False
if len(self.data) == 0:
return False
return True def min_length(self, min=-1):
if not self.is_null(False) and len(self.data) < min:
return False
return True def max_length(self, max):
if not self.is_null(False) and len(self.data) > max:
return False
return True def min(self, min):
try:
if int(self.data) < min:
return False
return True
except Exception, e:
print e
return False def max(self, max):
try:
if int(self.data) > max:
return False
return True
except Exception, e:
print e
return False def equal_to(self, data):
if self.data != data:
return False
return True def select_from(self, *args):
if self.data not in args:
return False
return True if __name__ == '__main__':
b = BaseForm({'username': 'o'})
print b.validate()
print 'ok'

 

python实现简单表单校验框架的更多相关文章

  1. Spring MVC 文件上传、Restful、表单校验框架

    目录 文件上传 Restful Restful 简介 Rest 行为常用约定方式 Restful开发入门 表单校验框架 表单校验框架介绍 快速入门 多规则校验 嵌套校验 分组校验 综合案例 实用校验范 ...

  2. 利用jquery.validate以及bootstrap的tooltip开发气泡式的表单校验组件

    表单校验是页面开发中非常常见的一类需求,相信每个前端开发人员都有这方面的经验.网上有很多成熟的表单校验框架,虽然按照它们默认的设计,用起来没有多大的问题,但是在实际工作中,表单校验有可能有比较复杂的个 ...

  3. Vue.js + Nuxt.js 项目中使用 Vee-validate 表单校验

    vee-validate 是为 Vue.js 量身打造的表单校验框架,允许您校验输入的内容并显示对应的错误提示信息.它内置了很多常见的校验规则,可以组合使用多种校验规则,大部分场景只需要配置就能实现开 ...

  4. Vee-validate 父组件获取子组件表单校验结果

    vee-validate 是为 Vue.js 量身打造的表单校验框架,允许您校验输入的内容并显示对应的错误提示信息.它内置了很多常见的校验规则,可以组合使用多种校验规则,大部分场景只需要配置就能实现开 ...

  5. JEECG 3.7.8 新版表单校验提示风格使用&升级方法(validform 新风格漂亮,布局简单)

    JEECG 表单校验采用的是validform,默认的校验提示需要占用页面布局,提示效果较传统.jeecg这个自定义的校验提示风格,不占用页面布局,提示效果也更美观,简单易用,让表单看起来更漂亮!!! ...

  6. 简单好用的表单校验插件——jQuery Validate基本使用方法总结

    jquery validate当前最新版本是1.17.0,下载链接是:https://github.com/jquery-validation/jquery-validation/releases/t ...

  7. easyui 进阶之表单校验、自定义校验

    前言 easyui是一种基于jQuery的用户界面插件集合,它为创建现代化,互动,JavaScript应用程序,提供必要的功能,完美支持HTML5网页的完整框架,节省网页开发的时间和规模.非常的简单易 ...

  8. js--吐血总结最近遇到的变态表单校验---element+原生+jq+easyUI(前端职业生涯见过的最烦的校验)

    最近写了无数各种形式的表单,记录下奇奇怪怪的校验规则~ 一:首先是element自带的rules校验规则: element作为常用框架,自带rules属性简单易懂,官方文档一目了然,不再赘述,应付常用 ...

  9. AngularJS 1.2.x 学习笔记(表单校验篇)

    https://my.oschina.net/cokolin/blog/526911 摘要: 本文首发于 blog.csdn.net/vipshop_ebs/article/details/39472 ...

随机推荐

  1. 每天一点css3聚沙成塔(一):transition

    transition 语法: transition:[ transition-property ] || [ transition-duration ] || [ transition-timing- ...

  2. CentOS 安装redis2.8.13 提醒"libc.so.6: version `GLIBC_2.14' not found"系统的glibc版本太低

    以下在系统CentOS 6.3 x86_64上操作 1.试图运行程序,提示"libc.so.6: version `GLIBC_2.14' not found",原因是系统的gli ...

  3. WPF中获取控件之间的相对位置

    1,获取元素相对于父控件的位置 使用Vector VisualTreeHelper.GetOffset(Visual visual)方法,其会返回visual在其父控件中的偏移量,然后你再将返回值的V ...

  4. scrollbarsstyle

    android:scrollbarStyle属性及滚动条和分割线覆盖问题 本文主要介绍android view的android:scrollbarStyle属性意义android:scrollbarS ...

  5. CSS之清除浮动

    一.清除浮动的目的. 1.当一个父元素的高度不写或为auto时,而且这个父元素内又有浮动的子元素,那么这时候该父元素的高度将不会自动适应子元素的高度,也可以说高度是0px; 有如下代码: <di ...

  6. shell printf格式化输出语句

    printf 命令用于格式化输出, 是echo命令的增强版.它是C语言printf()库函数的一个有限的变形,并且在语法上有些不同. 注意:printf 由 POSIX 标准所定义,移植性要比 ech ...

  7. Linux下程序崩溃,ulimit,coredump,gdbserver

    操作系统:Ubuntu10.04 前言:    在程序崩溃后,如何快速定位问题.    以下方法适用于开发调试阶段,不太适用成品.    本文着眼于嵌入式,PC方面更简单.    核心:gdbserv ...

  8. windows phone中,将crash report记录下来,写入文件,方便分析

    APP出现crash(崩溃)总是不能忍的 当我们连接调试器调试的时候,发现每当APP崩溃的时候 程序都会走到App.xaml.cs中的 // Code to execute on Unhandled ...

  9. Intersection of Two Linked Lists 解答

    Question Write a program to find the node at which the intersection of two singly linked lists begin ...

  10. 一起来学canvas (前言)

    codeyy - 一依丫丫 一起来学canvas (前言)