本文实例为大家分享了Django实现表单验证的具体代码,供大家参考,具体内容如下
models.py
class Users(models.Model): nickname = models.CharField(max_length=16, null=False, blank=False, unique=True) email = models.EmailField(max_length=32, null=False, blank=False, unique=True) password = models.CharField(max_length=64, null=False, blank=False) head = models.ImageField(default="decault.png") age = models.CharField(max_length=3,blank=True,null=True) sex = models.CharField(max_length=2, blank=True, null=True) isactivate = models.BooleanField(default=False) def save(self): if not self.password.startswith('pbkdf2_'): self.password = make_password(self.password) super().save()
form.py
from django import forms from django.core.exceptions import ValidationError from user.models import Users #定义验证器 def nickname_validate(nickname): u = Users.objects.filter(nickname=nickname) if len(u): print(len(u)) raise ValidationError('用户名已存在') #定义表单 class RegisterForm(forms.Form): nickname = forms.CharField(validators=[nickname_validate], label='用户名', max_length=16, min_length=4, required=True, widget= forms.TextInput(), ) password = forms.CharField(label='密码', max_length=64, min_length=6, required=True, widget=forms.PasswordInput()) email = forms.EmailField(label='邮箱', max_length=32, required=True) age = forms.CharField(label='年龄', max_length=3, required=False) sex = forms.ChoiceField(label='性别', choices = ((0,'男'),(1,'女'),), required=False)
view.py
from user.forms import RegisterForm from user.models import Users def register(request): if request.method == 'POST': form = RegisterForm(request.POST) if form.is_valid(): u = Users() u.nickname = form.cleaned_data['nickname'] u.email = form.cleaned_data['email'] u.password = form.cleaned_data['password'] u.age = form.cleaned_data['age'] u.sex = form.cleaned_data['sex'] u.save() return render(request,'user_info.html') else: return render(request, 'register.html',context={'form':form,'errors': form.errors}) else: form = RegisterForm() return render(request,'register.html',context={'form':form})
register.html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>注册</title> </head> <body> <form class="form" action="{% url 'user:register' %}" method="post"> {% csrf_token %} <table> {{ form.as_p }} </table> <button type="submit" class="btn btn-primary btn-block">注册 </button> <input type="hidden" name="next" value="{{ next }}"/> </form> </body> </html>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍AngularJS实现表单验证,包括了AngularJS实现表单验证的使用技巧和注意事项,需要的朋友参考一下 虽然我不是前端程序员,但明白前端做好验证是多么重要。 因为这样后端就可以多喘口气了,而且相比后端什么的果然还是前端可以提高用户的幸福感。 AngularJS提供了很方便的表单验证功能,在此记录一番。 首先从下面这段代码开始 input标签的一些验证选项,通常和HTML5标记搭
本文向大家介绍jquery实现简单的表单验证,包括了jquery实现简单的表单验证的使用技巧和注意事项,需要的朋友参考一下 jquery如何实现简单的表单验证,我们先跟大家分享一下实现思路。 大概思路: 先为每一个required添加必填的标记,用each()方法来实现。 在each()方法中先是创建一个元素,然后通过append()方法将创建的元素加入到父元素后面。 这里面的this用的很精髓
本文向大家介绍AngularJS实现表单手动验证和表单自动验证,包括了AngularJS实现表单手动验证和表单自动验证的使用技巧和注意事项,需要的朋友参考一下 AngularJS的表单验证大致有两种,一种是手动验证,一种是自动验证。 一、手动验证 所谓手动验证是通过AngularJS表单的属性来验证。而成为AngularJS表单必须满足两个条件: 1、给form元素加上novalidate="no
本文向大家介绍JavaScript实现表单验证功能,包括了JavaScript实现表单验证功能的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了JavaScript实现表单验证功能的具体代码,供大家参考,具体内容如下 以下是JavaScript的表单验证功能,可根据JS代码编写出你想要的HTML和CSS的代码。 关于正则表达式的使用,以及常用的正则表达式,笔者目前还在整理中,后期整理完
本文向大家介绍详解AngularJS实现表单验证,包括了详解AngularJS实现表单验证的使用技巧和注意事项,需要的朋友参考一下 开始学习AngularJS表单验证: 常用的表单验证指令 1. 必填项验证 某个表单输入是否已填写,只要在输入字段元素上添加HTML5标记required即可: 2. 最小长度 验证表单输入的文本长度是否大于某个最小值,在输入字段上使用指令ng-minleng= "{
本文向大家介绍jquery实现表单验证简单实例演示,包括了jquery实现表单验证简单实例演示的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了jquery实现表单验证代码。分享给大家供大家参考。具体如下: 运行效果截图如下: 具体代码如下: 直接上插件实现代码了,围绕代码进行讲解比较容易点: 先来说一说实现原理: 首先定义好正则,和相应的提示信息, 加上自定义che