04 django管理系统 - 部门管理 - 新增部门

在03,我们完成了部门列表的展示,下面进入新增部门的部分。

首先增加新增部门入口

html 复制代码
<div class="panel-heading">
    <a class="btn btn-primary" href="/depart/add/" role="button">添加部门</a>
</div>

配置URL路由

python 复制代码
urlpatterns = [
    # 部门管理
    path("dept/list/", dept.dept_list),
    path("dept/add/", dept.dept_add),
]

定义dept_add函数

python 复制代码
"""新建部门"""
def dept_add(request):
    pass

我们使用ModelForm来实现。先重写ModelForm类,放在utils文件夹中,bootstrap.py

python 复制代码
from django import forms

class BootStrap:
    bootstrap_exclude_fields = []

    def __init__(self, *args, **kwargs):
        super().__init__(*args, **kwargs)
        # 循环ModelForm中的所有字段,给每个字段的插件设置
        for name, field in self.fields.items():
            if name in self.bootstrap_exclude_fields:
                continue
            # 字段中有属性,保留原来的属性,没有属性,才增加。
            if field.widget.attrs:
                field.widget.attrs["class"] = "form-control"
                field.widget.attrs["placeholder"] = field.label
            else:
                field.widget.attrs = {
                    "class": "form-control",
                    "placeholder": field.label
                }


class BootStrapModelForm(BootStrap, forms.ModelForm):
    pass


class BootStrapForm(BootStrap, forms.Form):
    pass

然后我们接着定义DeptModelForm类,继承BootStrapModelForm

python 复制代码
"""部门类的ModelForm"""


class DeptModelForm(BootStrapModelForm):
    class Meta:
        model = Dept
        fields = "__all__"

接着继续定义函数dept_add的业务逻辑

python 复制代码
def dept_add(request):
    """
    1. 获取表单数据
    2. 校验数据
    3. 保存数据
    4. 跳转页面
    """
    title = '新建部门'
    if request.method == 'GET':
        form = DeptModelForm()
        return render(request, 'dept_add.html', {'form': form, 'title': title})

新建dept_add.html

html 复制代码
{% extends 'base.html' %}

{% block content %}

    <div class="container">
        <div class="panel panel-default">
            <div class="panel-heading">
                <h3 class="panel-title"> {{ title }} </h3>
            </div>
            <div class="panel-body">
                <form method="POST" action="" novalidate>
                    {% csrf_token %}

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

                    <button type="submit" class="btn btn-primary">提 交</button>
                </form>
            </div>
        </div>
    </div>

{% endblock %}

效果如下:

下面实现填写数据,并保存到数据库中去。使用ModelForm即可实现。

python 复制代码
"""新建部门"""


def dept_add(request):
    title = '新建部门'
    if request.method == 'GET':
        form = DeptModelForm()
        return render(request, 'dept_add.html', {'form': form, 'title': title})

    form = DeptModelForm(data=request.POST)
    if form.is_valid():
        form.save()
        return redirect('/dept/list')
    return render(request, 'dept_add.html', {'form': form, 'title': title})

效果如下:

到此,就实现了新建部门的功能。

相关推荐
友友马5 分钟前
『QT』窗口 (一)
开发语言·数据库·qt
q***78377 分钟前
SQL实现md5加密方法
数据库·sql
APIshop9 分钟前
Python 零基础写爬虫:一步步抓取商品详情(超细详解)
开发语言·爬虫·python
q***614118 分钟前
Spring中Aware的用法以及实现
java·数据库·spring
红树林0727 分钟前
渗透测试之sql注入--报错注入
数据库·sql·安全·web安全
u***276138 分钟前
TypeScript 与后端开发Node.js
javascript·typescript·node.js
AI科技星1 小时前
为什么宇宙无限大?
开发语言·数据结构·经验分享·线性代数·算法
星空的资源小屋1 小时前
跨平台下载神器ArrowDL,一网打尽所有资源
javascript·笔记·django
菜鸟小九1 小时前
mysql(锁)
数据库·mysql·oracle
c***42101 小时前
【Sql Server】随机查询一条表记录,并重重温回顾下自定义函数的封装和使用
数据库·性能优化