文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

django中模板继承与ModelForm怎么用

2023-06-30 11:18

关注

这篇文章主要讲解了“django中模板继承与ModelForm怎么用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“django中模板继承与ModelForm怎么用”吧!

模板的继承

完美在写html的时候会发现,自己多个html文件中又好多东西是一样的,包括静插件的引入 还有有些简单的css样式都不需要修改,这样完美就可以引入有关模板来方便操作

{% load static %}<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <title>Title</title>    <link rel="stylesheet" href="{% static 'plugins/bootstrap-3.4.1-dist/css/bootstrap.css' %}" rel="external nofollow" ></head><body><nav class="navbar navbar-default">...</nav><div>    {% block content %}{% endblock %}</div> <script src="{% static 'js/jquery-3.5.1.min.js' %}"></script><script src="{% static 'plugins/bootstrap-3.4.1-dist/js/bootstrap.min.js' %}"></script></body></html>

比如我们可以在模板文件中引入,然后写上{% block content %}{% endblock %}这样有关语法,便可以在其它相似的html中直接书写 div中的内容

{% extends "layout.html" %}{% block content %}     <div class="container">    ...    </div>{% endblock %}

form和ModelForm

在我们正常的操作中,如果想在有关列表中添加数据并且想要连接数据库拿到这些数据,我们得根据表单中的 name 属性来拿,比如我创建了这么多的数据数据 

class UserInfo(models.Model):    ''''员工表'''    name = models.CharField(verbose_name="姓名",max_length=32)    age = models.IntegerField(verbose_name="年龄")    password = models.CharField(verbose_name="密码",max_length=64)    account = models.DecimalField(verbose_name="账户余额",max_digits=10,decimal_places=2,default=0)    creat_time = models.DateTimeField(verbose_name="入职时间")

拿到数据,添加到数据库中

user = request.POST.get("user")pwg = request.POST.get("pwd")account = request.POST.get("ac")ctime = request.POST.get("ctime")# get中的内容是用户输入表单中的name的属性值,可以自己定义 models.UserInfo.object.creat(name=user,password=pwd ......)

这样做未免过于繁琐并且有这样的问题

-----用户提交的数据没有校验

-----页面上没有错误提示

-----页面上的每个字段都需要我们重新写一遍

-----关联的数据,必须手动获取并展示在页面中

但是我们通过django中自带的两个组件:Form和ModleForm

使用方法

view中

from django import formsclass UserAdd(forms.ModelForm):   #创建一个类,类中继承forms    name = forms.CharField(min_length=3)        #这里可以创建各类表单,也写一些约束条件,让html页面显示约束条件,因为我在我的django中已经在models中创建好了数据表,所有我在这里不再创建,在下面直接拿到我的数据表     title = forms.CharField(max_length=100, label='')    content = forms.CharField(widget=forms.Textarea, label='内容')    email = forms.EmailField(label='邮箱')    reply = forms.BooleanField(required=False, label='回复')     #拿到数据表    class Meta:        model = models.UserInfo        fields = ["name","password","age","creat_time","gender","depart"] def user_add(request):    '''添加用户'''    if request.method == "GET":        form = UserAdd()        return render(request,"user_add.html",{'form': form})

html中利用for循环便可以自动生成表单

<form method="post" novalidate>    {% csrf_token %}    {% for field in form %}      <div class="form-group">        <label>{{ field.label }}</label>        {{ field }}      </div>    {% endfor %}

我们也可以给表单加上各种样式

widgets = {    "name" : forms.TextInput(attrs={"class":"form-control"}),        }#这样写可能会有点繁琐,得多次定义,我们可以用类和面向对象来写    def __init__(self,*args,**kwargs):        super().__init__(*args,**kwargs)        for name,field in self.fields.items():#也可以加上判断条件    def __init__(self,*args,**kwargs):        super().__init__(*args,**kwargs)        for name,field in self.fields.items():            if name == "password":                continue            field.widget.attrs = {"class": "form-control"}

我们还可以加上各种判断

def user_add(request):    '''添加用户'''    if request.method == "GET":        form = UserAdd()        return render(request,"user_add.html",{'form': form})     form = UserAdd(data=request.POST)    #如果条件成立则添加到数据库中    if form.is_valid():        form.save()        return redirect('/user/list/')    else:        return render(request,"user_add.html",{'form': form})

在这里,用一句 form.save()便可以将所有你写的数据添加到数据库里

html中也可以显示各种错误,并加上各种条件,如这里的span标签

{% for field in form %}    <div class="form-group">        <label>{{ field.label }}</label>        {{ field }}        <span >{{ field.errors.0 }}</span>    </div>{% endfor %}

查看我们的输出结果,若满足条件则可以加入数据库,不满足则显示错误

django中模板继承与ModelForm怎么用

 我们还可以在设置中修改提示的语言

django中模板继承与ModelForm怎么用

感谢各位的阅读,以上就是“django中模板继承与ModelForm怎么用”的内容了,经过本文的学习后,相信大家对django中模板继承与ModelForm怎么用这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯