当前位置: 首页 > news >正文

Django中Model-Form验证

Django中Model-Form验证

class UserType(models.Model):
    caption=models.CharField(max_length=32)


class UserInfo(models.Model):
    username=models.CharField(max_length=32,verbose_name='用户名')
    email = models.EmailField(verbose_name='邮箱')

    user_type = models.ForeignKey(to='UserType',to_field='id',on_delete='on_delete')
models.py
class Modelform(forms.ModelForm):   # modelForm

    class Meta:                            #Meta类
        model = models.UserInfo
        fields = '__all__'    #__all__列出所有的字段
        # fields = ['username','email']
        # exclude = ['user_type']  #排除


def model_form(request):

    if request.method == "GET":
        obj = Modelform()
        return render(request,'modelform.html',{'obj':obj})
    elif request.method == "POST":
        obj = Modelform(request.POST)
        print(obj.is_valid())
        print(obj.cleaned_data)
        return render(request, 'modelform.html', {'obj': obj})
views.py
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>

<form action="/xiaoqing/model_form/"  method="post">
{% csrf_token %}
    {{ obj.as_p }}
<input type="submit" value="提交">
</form>

</body>
</html>
modelform.html
from django.forms import widgets as Fwidgets
class Modelform(forms.ModelForm):   # modelForm

    class Meta:
        model = models.UserInfo
        fields = '__all__'    #__all__列出所有的字段
        # fields = ['username','email']
        # exclude = ['user_type']  #排除
        labels = {'username':'用户名','email':'邮箱',}
        # 也可以这样设置  不在models.py里设置
        widgets = {
            'username': Fwidgets.Textarea(attrs={'class': 'c1'})

        }
        help_texts = {'username': '提示信息'}

        error_messages = {

            'email':{'required':'邮箱不能为空',}
        }

 Model-Form组件

ModelForm
    a.  class Meta:
            model,                           # 对应Model的
            fields=None,                     # 字段
            exclude=None,                    # 排除字段
            labels=None,                     # 提示信息
            help_texts=None,                 # 帮助提示信息
            widgets=None,                    # 自定义插件
            error_messages=None,             # 自定义错误信息(整体错误信息from django.core.exceptions import NON_FIELD_ERRORS)
            field_classes=None               # 自定义字段类 (也可以自定义字段)
            localized_fields=('birth_date',) # 本地化,如:根据不同时区显示数据
            如:
                数据库中
                    2016-12-27 04:10:57
                setting中的配置
                    TIME_ZONE = 'Asia/Shanghai'
                    USE_TZ = True
                则显示:
                    2016-12-27 12:10:57
    b. 验证执行过程
        is_valid -> full_clean -> 钩子 -> 整体错误
 
    c. 字典字段验证
        def clean_字段名(self):
            # 可以抛出异常
            # from django.core.exceptions import ValidationError
            return "新值"
    d. 用于验证
        model_form_obj = XXOOModelForm()
        model_form_obj.is_valid()
        model_form_obj.errors.as_json()
        model_form_obj.clean()
        model_form_obj.cleaned_data
    e. 用于创建
        model_form_obj = XXOOModelForm(request.POST)
        #### 页面显示,并提交 #####
        # 默认保存多对多
            obj = form.save(commit=True)
        # 不做任何操作,内部定义 save_m2m(用于保存多对多)
            obj = form.save(commit=False)
            obj.save()      # 保存单表信息
            obj.save_m2m()  # 保存关联多对多信息
 
    f. 用于更新和初始化
        obj = model.tb.objects.get(id=1)
        model_form_obj = XXOOModelForm(request.POST,instance=obj)
        ...
 
        PS: 单纯初始化
            model_form_obj = XXOOModelForm(initial={...})

 

转载于:https://www.cnblogs.com/sunhao96/p/9020201.html

相关文章:

  • win10 常用设置 桌面出来计算机图标,固定桌面摆好的图标设置方法,电脑设备ID方法...
  • D的去世给我的震撼
  • SAP云平台运行环境Cloud Foundry和Neo的区别
  • CAP理论的例子讲解
  • 欧拉函数 + 线性求法
  • 编写高质量JavaScript代码之并发
  • Python成长之路【第三篇】函数
  • Callable和Future用法示例
  • 谁说我们IT不重要???
  • linux-NAT连接外网
  • DataWorks支持PyODPS类型任务
  • JS 时间函数 / 格式化时间戳
  • THML DOM / Element 对象操作
  • [Excel VBA]单元格区域引用方式的小结
  • 量子计算机还没完全实现,硅谷已流行开量子计算聚会
  • “大数据应用场景”之隔壁老王(连载四)
  • Bootstrap JS插件Alert源码分析
  • CoolViewPager:即刻刷新,自定义边缘效果颜色,双向自动循环,内置垂直切换效果,想要的都在这里...
  • Invalidate和postInvalidate的区别
  • Java IO学习笔记一
  • JavaScript标准库系列——Math对象和Date对象(二)
  • JS 面试题总结
  • nginx(二):进阶配置介绍--rewrite用法,压缩,https虚拟主机等
  • opencv python Meanshift 和 Camshift
  • PHP CLI应用的调试原理
  • PHP那些事儿
  • Sublime text 3 3103 注册码
  • Terraform入门 - 1. 安装Terraform
  • Vue UI框架库开发介绍
  • 阿里云容器服务区块链解决方案全新升级 支持Hyperledger Fabric v1.1
  • 漂亮刷新控件-iOS
  • 什么软件可以剪辑音乐?
  • 问题之ssh中Host key verification failed的解决
  • 树莓派用上kodexplorer也能玩成私有网盘
  • ​DB-Engines 11月数据库排名:PostgreSQL坐稳同期涨幅榜冠军宝座
  • #我与Java虚拟机的故事#连载19:等我技术变强了,我会去看你的 ​
  • (bean配置类的注解开发)学习Spring的第十三天
  • (八)Docker网络跨主机通讯vxlan和vlan
  • (顶刊)一个基于分类代理模型的超多目标优化算法
  • (附源码)ssm高校实验室 毕业设计 800008
  • (简单有案例)前端实现主题切换、动态换肤的两种简单方式
  • (入门自用)--C++--抽象类--多态原理--虚表--1020
  • (转载)在C#用WM_COPYDATA消息来实现两个进程之间传递数据
  • .[backups@airmail.cc].faust勒索病毒的最新威胁:如何恢复您的数据?
  • .gitignore
  • .htaccess 强制https 单独排除某个目录
  • .NET CORE 第一节 创建基本的 asp.net core
  • .NET CORE 2.0发布后没有 VIEWS视图页面文件
  • .net core 6 redis操作类
  • .net 简单实现MD5
  • .net 逐行读取大文本文件_如何使用 Java 灵活读取 Excel 内容 ?
  • .net6Api后台+uniapp导出Excel
  • .Net组件程序设计之线程、并发管理(一)
  • @ConditionalOnProperty注解使用说明
  • [ CTF ] WriteUp-2022年春秋杯网络安全联赛-冬季赛