modelform自动生成表单

本文介绍了如何在Django中创建`Bumen`和`UserInfo`两个模型,以及如何在views.py中使用`UserInfoForm`处理用户信息表单,包括表单字段、错误处理和HTML模板展示。
摘要由CSDN通过智能技术生成

model.py

class Bumen(models.Model):
    name=models.CharField(verbose_name='部门',max_length=255)
    
    #需要显示这个类的时候,指定返回这个类的name字段。
    def __str__(self):
        return self.name

class UserInfo(models.Model):
    name = models.CharField(max_length=255, unique=True, verbose_name='')
    nk_name = models.CharField(max_length=255,  verbose_name='',null=True, blank=True)
    age = models.IntegerField(verbose_name='',null=True, blank=True)
    shijian=models.TextField(verbose_name="时间")
    bumen=models.ForeignKey(to=Bumen,verbose_name="部门",on_delete=models.DO_NOTHING)

views.py

from django import forms
from django.shortcuts import render,HttpResponse,redirect



# Create your views here.
from . import models
#使用modelform

class UserInfoForm(forms.ModelForm):
    #xxx=forms.CharField(max_length=11)#自定义字段
    class Meta:
        model = models.UserInfo
        fields = ['name','age','shijian','bumen']

    def __init__(self,*args,**kwargs):
        super(UserInfoForm,self).__init__(*args,**kwargs)
        for name,filed in self.files.items():
            if name=='password':
                continue
            filed.widget.attrs={"class","form-control"}

def index(request):
    form=UserInfoForm()
    return render(request,'userinfoform.html',{"form":form})

html页面

<div>
    <form action="" method="post">
        {% csrf_token %}
        {% for field in form %}
        	{{ field.label }}:{{ field }}
            <span style="color: red">{{ field.errors }}</span>
        {% endfor %}
        
        
    </form>
</div>

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值