Django4全栈进阶之路20 项目实战(三种方式开发部门管理):方式一:FBV
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的更多相关文章
- web前端全栈学习之路
web前端全栈学习之路 --- 陆续更新中 一.HTML相关 1.HTML常用标签:http://www.cnblogs.com/wyb666/p/8733699.html 2.HTML5基础: 3. ...
- 你的Node应用,对接分布式链路跟踪系统了吗?(一) 原创: 金炳 Node全栈进阶 4天前 戳蓝字「Node全栈进阶」关注我们哦
你的Node应用,对接分布式链路跟踪系统了吗?(一) 原创: 金炳 Node全栈进阶 4天前 戳蓝字「Node全栈进阶」关注我们哦
- C#.Net全栈工程师之路-学习路径
C#.Net全栈工程师之路-学习路径 按架构分: C/S架构: B/S架构: Mobile移动开发: 按技术点分: C#编程基础以及OOP面向对象编程: 数据库基础以及高级应用(MYSQL+MSSQL ...
- miniFTP项目实战三
项目简介: 在Linux环境下用C语言开发的Vsftpd的简化版本,拥有部分Vsftpd功能和相同的FTP协议,系统的主要架构采用多进程模型,每当有一个新的客户连接到达,主进程就会派生出一个ftp服务 ...
- GJM :用JIRA管理你的项目(三)基于LDAP用户管理 [转载]
感谢您的阅读.喜欢的.有用的就请大哥大嫂们高抬贵手"推荐一下"吧!你的精神支持是博主强大的写作动力以及转载收藏动力.欢迎转载! 版权声明:本文原创发表于 [请点击连接前往] ,未经 ...
- Eclipse导入SVN项目的三种方式
Eclipse导入SVN项目的三种方式 一.直接Import导入: 1.点击 File --> Import,进入导入项目窗口 2.选择从SVN检出项目,点击Next 3.选择创建新的资源库位置 ...
- 在Tomcat中部署web项目的三种方式
搬瓦工搭建SS教程 SSR免费节点:http://www.xiaokeli.me 在这里介绍在Tomcat中部署web项目的三种方式: 1.部署解包的webapp目录 2.打包的war文件 3.Man ...
- tomcat发布web项目的三种方式
tomcat发布web项目的三种方式 方式一: 配置tomcat 安装目录下的conf/server.xml <Host name="loaclhost">标签里面添加 ...
- 用Visual C++创建WPF项目的三种主要方法
用Visual C++创建WPF项目的三种主要方法 The problem with using XAML from C++ Because C++ doesn't support partial c ...
- 战争热诚的python全栈开发之路
从学习python开始,一直是自己摸索,但是时间不等人啊,所以自己为了节省时间,决定报个班系统学习,下面整理的文章都是自己学习后,认为重要的需要弄懂的知识点,做出链接,一方面是为了自己找的话方便,一方 ...
随机推荐
- OSPF之路由撤销
- 了解 BASH
管理整个计算机硬件的其实是操作系统的核心(kernel),这个核心是需要被保护的.所以使用者就只能通过shell来跟核心沟通,以让核心达到想要的工作.那么系统中有多少 shell?为什么要使用 bas ...
- 15.AQS的今生,构建出JUC的基础
大家好,我是王有志,欢迎和我聊技术,聊漂泊在外的生活.快来加入我们的Java提桶跑路群:共同富裕的Java人. <AQS的前世,从1990年的论文说起>中我们已经对AQS做了简单的介绍,并 ...
- 基于el-cascader级联选择器实现只有最后一级可以多选(已发布到npm & github)
github地址:地址 背景: 我们经常级联合选择器多选的需求,但是element UI提供的级联选择器并不能只多选最后一级,所以我考虑基于element UI的级联选择器优化一下,实现可以多选最后一 ...
- AI开发实践:关于停车场中车辆识别与跟踪
摘要:本案例我们使用FairMOT进行车辆检测与跟踪.yolov5进行车牌检测.crnn进行车牌识别,在停车场入口.出口.停车位对车辆进行跟踪与车牌识别,无论停车场路线多复杂,小车在你掌控之中! 本文 ...
- pysimplegui之常用元素介绍
1文本元素 | T == Txt == Text 2多行文本sg.Multiline('This is what a Multi-line Text Element looks like', size ...
- [MAUI 项目实战] 手势控制音乐播放器(一): 概述与架构
这是一篇系列博文.请关注我,学习更多.NET MAUI开发知识! [MAUI 项目实战] 手势控制音乐播放器(一): 概述与架构 [MAUI 项目实战] 手势控制音乐播放器(二): 手势交互 [MAU ...
- 微信小程序隐藏页面滚动条
开发小程序时,经常会碰到页面长度超过屏幕高度,然后下拉时会出现滚动条,对于一些有强迫症的人来说是不可忍受的. 网上看了好多,写的.都评论有起作用或者不起作用的. 我在这分享一个全局隐藏滚动条的方式. ...
- (一)pyahocorasick和marisa_trie,字符串快速查找的python包,自然语言处理,命名实体识别可用的高效包
Pyahocorasick Pyahocorasick是一个基于AC自动机算法的字符串匹配工具.它可以用于快速查找多个短字符串在一个长字符串中的所有出现位置.Pyahocorasick可以在构建状态机 ...
- 【解决方法】ASP.NET web 提示错误:CS0103 当前上下文中不存在名称“******”
问题描述 操作环境与场景: 在 Windows 10 中 Visual Studio 2017 编写网页时,提示报错: 错误 CS0103 当前上下文中不存在名称"******" ...