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开始,一直是自己摸索,但是时间不等人啊,所以自己为了节省时间,决定报个班系统学习,下面整理的文章都是自己学习后,认为重要的需要弄懂的知识点,做出链接,一方面是为了自己找的话方便,一方 ...
随机推荐
- leetcode medium 记录 1-50
# Title Solution 二刷 Difficulty 备注 2 Add Two Numbers X Medium 3 Longest Substring Wi ...
- vivo全球商城:库存系统架构设计与实践
作者:vivo官网商城开发团队 - Xu Yi.Yan Chao 本文是vivo商城系列文章,主要介绍vivo商城库存系统发展历程.架构设计思路以及应对业务场景的实践. 一.业务背景 库存系统是电商商 ...
- Java所用相关软件的大致安装流程
JAVA下载流程 一.相关环境的安装与配置 1.JDK的下载 去官网搜索相应的java版本,并进行下载 官网链接:www.xfdown.com/soft/125774.html在该链接下,可以下载ja ...
- 在jsp页面int和String类型的相互转换
浅浅地来做一个对比吧! .java文件 int转成string类型:String s=String.valueOf(int m); String转成int类型:int m=Integer.parseI ...
- SpringBoot——自定义自动配置与起步依赖
SpringBoot--自定义自动配置与起步依赖 SpringBoot为我们提供了灵活强大的自动配置与起步依赖功能,接下来我们参考其实现原理,实现专属于我们自己的自动配置与起步依赖. 不仅如此,我们对 ...
- Django笔记一之运行系统、创建视图并访问
从这一篇笔记开始将根据 Django 的官方文档,阅读整理之后,出一系列笔记教程,用作新手入门教程或者自己做查阅. 此次 Django 的版本为 3.2,且之后的一系列笔记都将以这个版本为基础,做功能 ...
- fullcalendar 日历插件的使用
[需求]:使用 fullcalendar日历插件,完成如下功能:可以进行拖动,点击空白处添加,双击后修改和删除等功能.API 链接
- Django笔记六之外键ForeignKey介绍
这一篇笔记介绍 Django 系统 model 的外键处理,ForeignKey 以及相应的处理方法. 这是一种一对多的字段类型,表示两张表之间的关联关系. 本篇笔记的目录如下: on_delete ...
- SpringBoot集成海康网络设备SDK
目录 SDK介绍 概述 功能 下载 对接指南 集成 初始化项目 初始化SDK 初始化SDK概述 新建AppRunner 新建SdkInitService 新建InitSdkTask 新建 HCNetS ...
- Synchronized和Volatile的对比
Synchronized和Volatile是并发中的两大关键字,有相似性和不同点. Synchronized更详细介绍参考https://www.cnblogs.com/spark-cc/p/1706 ...