1、模型

from django.db import models
from django.contrib.auth.models import User # Create your models here.
class Department(models.Model):
name = models.CharField(max_length=255, verbose_name='部门名称')
parent = models.ForeignKey('self', on_delete=models.CASCADE, null=True, blank=True, related_name='children',
verbose_name='父级部门')
description = models.TextField(blank=True, null=True, verbose_name='部门介绍')
sort = models.IntegerField(default=1, verbose_name="显示排序", help_text="显示排序")
owner = models.CharField(max_length=32, verbose_name="负责人", null=True, blank=True, help_text="负责人")
phone = models.CharField(max_length=32, verbose_name="联系电话", null=True, blank=True, help_text="联系电话")
email = models.EmailField(max_length=32, verbose_name="邮箱", null=True, blank=True, help_text="邮箱")
status = models.BooleanField(default=True, verbose_name="部门状态", null=True, blank=True, help_text="部门状态")
created_by = models.ForeignKey(User, on_delete=models.CASCADE, related_name='departments_created', to_field='id',
verbose_name='创建账号')
created_at = models.DateTimeField(auto_now_add=True, verbose_name='创建时间')
updated_by = models.ForeignKey(User, on_delete=models.CASCADE, related_name='departments_updated', to_field='id',
verbose_name='修改账号')
updated_at = models.DateTimeField(auto_now=True, verbose_name='最后修改时间') def __str__(self):
return self.name class Meta:
verbose_name = '部门'
verbose_name_plural = '部门'

2、视图

from django.contrib.auth.decorators import login_required
from django.http import HttpResponseBadRequest
from django.shortcuts import redirect, render, get_object_or_404 from BaseApp.models import Department @login_required
def depart_list_view(request):
depart = Department.objects.all
if depart:
return render(request, 'base/depart/depart_list.html', {'departments': depart})
else:
error_msg = "No data was found"
return render(request, 'base/depart/depart_list.html', {'error_msg': error_msg}) @login_required
def depart_create_view(request):
if request.method == 'POST':
name = request.POST.get('name')
description = request.POST.get('description')
if not name:
# return HttpResponseBadRequest("部门名称不能为空")
error_msg = '部门名称不能为空'
return render(request, 'base/depart/depart_add.html', {'error_msg': error_msg})
# 判断部门是否已经存在
if Department.objects.filter(name=name).exists():
# return HttpResponseBadRequest("部门已经存在")
error_msg = '部门已经存在'
return render(request, 'base/depart/depart_add.html', {'error_msg': error_msg})
if name and description:
Department.objects.create(name=name, description=description)
return redirect('depart_list')
return render(request, 'base/depart/depart_add.html') @login_required
def depart_update_view(request, pk):
department = get_object_or_404(Department, pk=pk)
if request.method == 'POST':
name = request.POST.get('name')
description = request.POST.get('description')
if not name:
return HttpResponseBadRequest("部门名称不能为空")
department.name = name
department.description = description
department.save()
return redirect('depart_list') return render(request, 'base/depart/depart_edit.html', {'department': department}) @login_required
def depart_delete_view(request, pk):
try:
qs = Department.objects.get(id=pk)
except Department.DoesNotExist:
error_msg = '部门不存在'
return redirect('depart_list', error_msg=error_msg)
else:
qs.delete()
return redirect('depart_list')

3、路由

from django.urls import path

from . import views

# 路由
urlpatterns = [
# FBV模式
path('depart/list/', views.depart_list_view, name='depart_list'),
path('depart/add/', views.depart_create_view, name='depart_add'),
path('depart/edit/<int:pk>/', views.depart_update_view, name='depart_edit'),
path('depart/delete/<int:pk>/', views.depart_delete_view, name='depart_delete'),

4、前端模板

depart_add.html

{% extends 'base.html' %}
{% block content %}
<div class="card mt-3">
<div class="card-header"> 新增部门</div>
<div class="card-body">
<form method="POST">
{% csrf_token %}
{% if error_msg %}
<p class="error">{{ error_msg }}</p>
{% endif %}
<div class="form-group">
<label for="name">部门名称:</label>
<input type="text" id="name" name="name" required class="form-control">
</div>
<br>
<div class="form-group">
<label for="description">部门介绍:</label>
<textarea id="description" required class="form-control"></textarea>
</div>
<br>
<button type="submit" class="btn btn-primary">保存</button>
</form>
</div>
</div>
{% endblock %}

depart_edit.html

{% extends 'base.html' %}
{% block content %}
<div class="card mt-3">
<div class="card-header">编辑部门信息</div>
<div class="card-body">
<form method="post">
{% csrf_token %}
<div class="form-group">
<label for="name">部门名称</label>
<input type="text" class="form-control" id="name" name="name" value="{{ department.name }}" required>
</div>
<div class="form-group">
<label for="description">部门描述</label>
<textarea class="form-control" id="description" name="description" rows="3">{{ department.description }}</textarea>
</div>
<button type="submit" class="btn btn-primary">保存</button>
</form>
</div>
</div>
{% endblock %}

depart_list.html

{% extends 'base.html' %}
{% block content %}
<div style="margin-top: 16px;">
<a class="btn btn-primary" href="{% url 'depart_add' %}">新增部门</a>
</div>
<div class="card mt-3">
<div class="card-header"> 部门列表</div>
<div class="card-body">
<table class="table table-bordered">
<thead>
<tr>
<th>部门名称</th>
<th>部门介绍</th>
<th>操作</th>
</tr>
</thead>
<tbody>
{% for department in departments %}
<tr>
<td>
{{ department.name }}
</td>
<td>
{{ department.description }}
</td>
<td>
<a class="btn btn-primary btn-xs"
href="{% url 'depart_edit' pk=department.id %}">编辑</a>
<a class="btn btn-danger btn-xs"
href="{% url 'depart_delete' pk=department.id %}"
onclick="return confirm('确定要删除吗?')">删除</a>
</td>
</tr>
{% empty %}
<tr>
No departments found.
</tr>
{% endfor %}
</tbody>
</table>
</div>
</div>
{% endblock %}

Django4全栈进阶之路20 项目实战(三种方式开发部门管理):方式一:FBV的更多相关文章

  1. web前端全栈学习之路

    web前端全栈学习之路 --- 陆续更新中 一.HTML相关 1.HTML常用标签:http://www.cnblogs.com/wyb666/p/8733699.html 2.HTML5基础: 3. ...

  2. 你的Node应用,对接分布式链路跟踪系统了吗?(一) 原创: 金炳 Node全栈进阶 4天前 戳蓝字「Node全栈进阶」关注我们哦

    你的Node应用,对接分布式链路跟踪系统了吗?(一) 原创: 金炳 Node全栈进阶 4天前 戳蓝字「Node全栈进阶」关注我们哦

  3. C#.Net全栈工程师之路-学习路径

    C#.Net全栈工程师之路-学习路径 按架构分: C/S架构: B/S架构: Mobile移动开发: 按技术点分: C#编程基础以及OOP面向对象编程: 数据库基础以及高级应用(MYSQL+MSSQL ...

  4. miniFTP项目实战三

    项目简介: 在Linux环境下用C语言开发的Vsftpd的简化版本,拥有部分Vsftpd功能和相同的FTP协议,系统的主要架构采用多进程模型,每当有一个新的客户连接到达,主进程就会派生出一个ftp服务 ...

  5. GJM :用JIRA管理你的项目(三)基于LDAP用户管理 [转载]

    感谢您的阅读.喜欢的.有用的就请大哥大嫂们高抬贵手"推荐一下"吧!你的精神支持是博主强大的写作动力以及转载收藏动力.欢迎转载! 版权声明:本文原创发表于 [请点击连接前往] ,未经 ...

  6. Eclipse导入SVN项目的三种方式

    Eclipse导入SVN项目的三种方式 一.直接Import导入: 1.点击 File --> Import,进入导入项目窗口 2.选择从SVN检出项目,点击Next 3.选择创建新的资源库位置 ...

  7. 在Tomcat中部署web项目的三种方式

    搬瓦工搭建SS教程 SSR免费节点:http://www.xiaokeli.me 在这里介绍在Tomcat中部署web项目的三种方式: 1.部署解包的webapp目录 2.打包的war文件 3.Man ...

  8. tomcat发布web项目的三种方式

    tomcat发布web项目的三种方式 方式一: 配置tomcat 安装目录下的conf/server.xml <Host name="loaclhost">标签里面添加 ...

  9. 用Visual C++创建WPF项目的三种主要方法

    用Visual C++创建WPF项目的三种主要方法 The problem with using XAML from C++ Because C++ doesn't support partial c ...

  10. 战争热诚的python全栈开发之路

    从学习python开始,一直是自己摸索,但是时间不等人啊,所以自己为了节省时间,决定报个班系统学习,下面整理的文章都是自己学习后,认为重要的需要弄懂的知识点,做出链接,一方面是为了自己找的话方便,一方 ...

随机推荐

  1. strtok实现想到的...

    1.实现容易,实现的方法很难想到 比如strtok函数 /* 获取第一个子字符串 */ token = strtok(str, s); /* 继续获取其他的子字符串 */ while( token ! ...

  2. 密码破解-hashcat的简单使用

    在我们抓取到系统的hash值之后,需要通过一些工具来破解密码 hashcat是一款可以基于显卡暴力破解密码的工具,几乎支持了所有常见的加密,并且支持各种姿势的密码搭配 在kali Linux中自带的有 ...

  3. msfconsole的使用

    msfconsole是metasploit中的一个工具: msfconsole集成了很多漏洞的利用的脚本,并且使用起来很简单的网络安全工具 在终端输入msfconsole命令即可进入msf的控制台,m ...

  4. Javaweb基础复习------EL表达式+JSTL-if&foreach

    EL表达式------简化JSP页面的Java代码 主要功能是------获取数据(语法:${data}) 举例: //ServletDemo1.java package com.example.se ...

  5. 11.7 消除闪烁(1)(harib08g)

    ps:看书比较急,有错误的地方欢迎指正,不细致的地方我会持续的修改 11.7 消除闪烁(1)(harib08g) 11.6 高速计数器(harib08f)存在闪烁的问题,产生原因:刷新时会从低到高进行 ...

  6. 《程序员的自我修养》学习笔记——不一样的hello world【第四弹】

    不一样的hello world Linux 的系统调用 通过glibc提供的库函数 glibc 是 Linux 下使用的开源的标准 C 库,它是 GNU 发布的 libc 库,即运行时库.glibc ...

  7. ACM需要知道的STL小技巧

    天天用stl,但是有一些小技巧如果不知道,偶尔会导致TLE,这里说几个打比赛需要用到的. 主要是大概了解一下其底层原理:https://www.jianshu.com/p/834cc223bb57 就 ...

  8. 学习笔记if

  9. Java 内存模型(二)

    Java 内存模型(二) happens-before ​ JSR-133 提出了 happens-before 的概念,通过这个概念来阐述操作之间的内存可见性.如果一个操作执行的结果需要对另一个操作 ...

  10. 两条命令搞定 ChatGPT API 的调用问题

    自2022年11月30日 OpenAI 发布 ChatGPT 以来,虽然时有唱衰的声音出现,但在OpenAI不断推陈出新,陆续发布了OpenAPI.GPT-4.ChatGPT Plugins之后,似乎 ...