【1029 | Day55】Form组件

怎甘沉沦 提交于 2019-12-02 19:41:34

4. form组件

4.1 form组件的功能

1.搭建前端页面 >>> 渲染页面
2.获取前端用户提交的数据校验 >>> 校验数据
3.对数据的校验的结果 展示到前端页面给用户查看 >>> 展示错误信息

4.2 form组件的使用

自己要先写一个类

from django import forms  class MyRegForm(forms.Form):     username = forms.CharField(min_length=3,max_length=8)     password = forms.CharField(min_length=3,max_length=8)     email = forms.EmailField()

4.3 校验数据

from app01 import views  # 1.给自定义的类传一个字典 obj = views.MyRegForm({'username':'jason','password':'12','email':'123'})  # 2.判断数据是否全部合法 obj.is_valid()  # 只有数据全部符合要求才会是True Out[4]: False  # 3.查看符合校验规则的数据 obj.cleaned_data Out[5]: {'username': 'jason'}  # 4.查看不符合条件的数据以及不符合的原因是什么 obj.errors Out[6]:  {         'password': ['Ensure this value has at least 3 characters (it has 2).'],         'email': ['Enter a valid email address.']     }              # 5.校验数据的时候 默认情况下类里面所有的字段都必须传值 obj = views.MyRegForm({'username':'jason','password':'123'}) obj.is_valid() Out[12]: False obj.errors Out[13]: {'email': ['This field is required.']}  # 6.默认情况下可以多传 但是绝对不能少传 obj = views.MyRegForm({'username':'jason','password':'1233','email':'123@qq.com','xxx':'ooo'}) obj.is_valid() Out[15]: True

4.4 渲染页面

forms组件只会帮你渲染获取用户输入(输入,选择,下拉框...)的标签 ,提交按钮需要你自己手动写

4.4.1 三种渲染前端页面的方式

<p>三种渲染前端页面的方式</p>  <p>第一种渲染前端页面的方式:封装程度太高了 标签样式及参数不方便调整 可扩展性差(不推荐使用)     {{ form_obj.as_p }}     {{ form_obj.as_ul }} </p>  <p>第二种渲染页面的方式:扩展性较高 不足之处在于 需要你手写的代码量比较多(不推荐使用)</p> <p>     {{ form_obj.username.label }}{{ form_obj.username }} </p> <p>     {{ form_obj.password.label }}{{ form_obj.password }} </p> <p>     {{ form_obj.email.label }}{{ form_obj.email }} </p>  <p>第三种渲染前端页面的方式:代码量和扩展性都很高(推荐使用)</p> {% for foo in form_obj %}     <p>{{ foo.label }}{{ foo }}</p> {% endfor %}

这一块还是比较简单的,动手试一试吧~

4.5 展示错误信息

4.5.1 取消前端的校验

<form action="" method="post" novalidate>

注意,此处form表单中添加一个参数即可!!!

跟我念一遍,No--Valid--Date!!!

4.5.2 展示错误信息

对象.errors.0的方法,然后利用error_message=展示错误信息。

<form action="" method="post" novalidate>     {% for foo in form_obj %}         <p>             {{ foo.label }}:{{ foo }}             <span style="color: red">{{ foo.errors.0 }}</span>         </p>     {% endfor %}     <input type="submit"> </form>
class MyRegForm(forms.Form):     username = forms.CharField(min_length=3, max_length=8, label='用户名',                                error_messages={                                    'min_length': '用户名最短三位',                                    'max_length': '用户名最长八位',                                    'required': '用户名不能为空'                                }, initial='我是初始值', required=False                                )          password = forms.CharField(min_length=3, max_length=8, label='密码', error_messages={                                     'min_length': '密码最短三位',                                     'max_length': '密码最长八位',                                     'required': '密码不能为空'                                 })          email = forms.EmailField(label='邮箱', error_messages={                                     'required': '邮箱不能为空',                                     'invalid': '邮箱格式不正确'                                 }, required=False) 

4.6 forms组件钩子函数

4.6.1 局部钩子

  • 当你需要对某一个字段数据进行额外的一些列校验,可以考虑使用钩子函数
  • 针对单个字段的,使用局部钩子
def clean_username(self):     username = self.cleaned_data.get('username')     if '陈伟霆' in username:     # 给username字段下面提示错误信息         self.add_error('username','用户名不符合社会主义核心价值观')     return username

4.6.2 全局钩子

  • 针对多个字段的校验,使用全局钩子
  • 举个栗子:校验两次密码是否一致
def clean(self):     password = self.cleaned_data.get('password')     confirm_password = self.cleaned_data.get('confirm_password')     if not password == confirm_password:         self.add_error('confirm_password','两次密码不一致')     return self.cleaned_data

4.7 改变input框的type属性值

  • widget= widgets.TextInput()
  • widget=widgets.PasswordInput()

4.8 form-control属性

一切都做的差不多的时候,我们就觉得这个表单样式也太丑了吧!!!作为颜控,这怎么能忍受得了!

那么,如何让forms组件渲染出来的input框有form-control类属性?

widget= widgets.TextInput(attrs={'class':'form-control others'})  # 如果有多个类属性 空格隔开 widget= widgets.PasswordInput(attrs={'class':'form-control others'})

每个字段 还支持正则校验

  • from django import forms
  • from django.forms import Form
  • from django.core.validators import RegexValidator
    class MyForm(Form):         user = forms.CharField(         validators=[RegexValidator(r'^[0-9]+$', '请输入数字'), RegexValidator(r'^159[0-9]+$', '数字必须以159开头')],         )

好了,今天的内容差不多就是这些,都是精华,看我博客的人都必须掌握!!!阿拉搜!!睡觉了

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!