Django4全栈进阶之路22 项目实战(三种方式开发部门管理):方式三:FBV+ModelForm+get_object_or_404
1、视图
@login_required
def department_list_view(request):
departments = Department.objects.all()
return render(request, 'base/depart/department_list.html', {'departments': departments})
# department = DepartmentsForm()
# return render(request, 'base/depart/department_list.html', {'department': department}) def department_detail_view(request, pk):
department = get_object_or_404(Department, pk=pk)
return render(request, 'base/depart/department_detail.html', {'department': department}) @login_required
def department_create_view(request):
if request.method == 'POST':
form = DepartmentsForm(request.POST)
if form.is_valid():
department = form.save(commit=False)
department.created_by = request.user
department.updated_by = request.user
department.save()
# return redirect('department_detail', pk=department.pk)
return redirect('department_list')
else:
form = DepartmentsForm()
return render(request, 'base/depart/department_create.html', {'form': form}) @login_required
def department_edit_view(request, pk):
department = get_object_or_404(Department, pk=pk)
if request.method == 'POST':
form = DepartmentsForm(request.POST, instance=department)
if form.is_valid():
department = form.save(commit=False)
department.updated_by = request.user
# return redirect('department_detail', pk=department.pk)
return redirect('department_list')
else:
form = DepartmentsForm(instance=department)
return render(request, 'base/depart/department_edit.html', {'form': form}) @login_required
def department_delete_View(request, pk):
department = get_object_or_404(Department, pk=pk)
if request.method == 'POST':
department.delete()
return redirect('department_list')
return render(request, 'base/depart/department_delete.html', {'department': department})
2、路由
urlpatterns = [
# FBV模式+ ModelForm
path('department/', views.department_list_view, name='department_list'),
path('department/<int:pk>/', views.department_detail_view, name='department_detail'),
path('department/add/', views.department_create_view, name='department_add'),
path('department/<int:pk>/update/', views.department_edit_view, name="department_edit"),
path('depart/delete/<int:pk>/', views.depart_delete_view, name='department_delete'),
]
3、模块
department_list.html
{% extends 'base.html' %}
{% block content %}
<div style="margin-top: 16px;">
<a href="{% url 'department_add' %}" class="btn btn-primary mb-3">添加部门</a>
</div>
<div class="card mt-3">
<div class="card-header">部门列表</div>
<div class="card-body">
<table class="table table-bordered">
<thead>
<tr>
<th>ID</th>
<th>部门名称</th>
<th>父级部门</th>
<th>显示排序</th>
<th>负责人</th>
<th>联系电话</th>
<th>邮箱</th>
<th>部门状态</th>
<th>操作</th>
</tr>
</thead>
<tbody>
{% for department in departments %}
<tr>
<td>{{ department.id }}</td>
<td>{{ department.name }}</td>
<td>{{ department.parent }}</td>
<td>{{ department.sort }}</td>
<td>{{ department.owner }}</td>
<td>{{ department.phone }}</td>
<td>{{ department.email }}</td>
<td>{{ department.status }}</td>
<td>
<a href="{% url 'department_detail' department.pk %}" class="btn btn-primary btn-sm">详情</a>
<a href="{% url 'department_edit' department.pk %}" class="btn btn-success btn-sm">编辑</a>
<a href="{% url 'department_delete' department.pk %}" class="btn btn-danger btn-sm">删除</a>
</td>
</tr>
{% empty %}
<tr>
<td colspan="9" style="text-align: center;">No departments yet.</td>
</tr>
{% endfor %}
</tbody>
</table>
{% endblock %}
</div>
</div>
department_create.html
{% block content %}
{% include 'base/depart/department_form.html' with form=form button_text='新增' form_title="新增部门" %}
{% endblock %}
department_update.html
{% block content %}
{% include 'base/depart/department_form.html' with form=form button_text='保存' form_title='编辑部门' %}
{% endblock %}
department_form.html
{% extends 'base.html' %}
{% load widget_tweaks %}
{% block content %}
<div class="card mt-3">
<div class="card-header">
{{ form_title }}
</div>
<div class="card-body">
<form method="post">
{% csrf_token %}
<div class="form-group">
<label for="{{ form.name.id_for_label }}">部门名称:</label>
{{ form.name|attr:"class:form-control" }}
</div>
<div class="form-group">
<label for="{{ form.parent.id_for_label }}">父级部门:</label>
{{ form.parent|attr:"class:form-control" }}
</div>
<div class="form-group">
<label for="{{ form.description.id_for_label }}">部门介绍:</label>
{{ form.description|attr:"class:form-control" }}
</div>
<div class="form-group">
<label for="{{ form.sort.id_for_label }}">显示排序:</label>
{{ form.sort|attr:"class:form-control" }}
</div>
<div class="form-group">
<label for="{{ form.owner.id_for_label }}">负责人:</label>
{{ form.owner|attr:"class:form-control" }}
</div>
<div class="form-group">
<label for="{{ form.phone.id_for_label }}">联系电话:</label>
{{ form.phone|attr:"class:form-control" }}
</div>
<div class="form-group">
<label for="{{ form.email.id_for_label }}">邮箱:</label>
{{ form.email|attr:"class:form-control" }}
</div>
<div class="form-group">
<label for="{{ form.status.id_for_label }}">部门状态:</label>
{{ form.status|attr:"class:form-control"}}
</div>
<button type="submit" class="btn btn-primary"> {{ button_text }}</button>
</form>
</div>
</div>
{% endblock %}
department_detail.html
{% extends 'base.html' %}
{% block content %}
<h1>{{ department.name }}</h1>
<p>{{ department.parent.name }}</p>
<p>{{ department.description }}</p>
<p>{{ department.sort }}</p>
<p>{{ department.owner }}</p>
<p>{{ department.email }}</p>
<p>{{ department.created_by.username }}</p>
<p>{{ department.created_at }}</p>
<p>{{ department.updated_by.username }}</p>
<p>{{ department.updated_at }}</p>
<a href="{% url 'department_edit' department.pk %}" class="btn btn-success btn-sm">编辑</a>
<a href="{% url 'department_delete' department.pk %}" class="btn btn-danger btn-sm">删除</a>
{% endblock %}
department_delete.html
{% extends 'base.html' %}
{% block content %}
<h1>Confirm delete</h1>
<p>Are you sure you want to delete department "{{ department.name }}"?</p>
<form method="post">
{% csrf_token %}
<button type="submit" class="btn btn-danger">Yes, delete</button>
<a href="{% url 'department_list' %}" class="btn btn-secondary">No, cancel</a>
</form>
{% endblock %}
Django4全栈进阶之路22 项目实战(三种方式开发部门管理):方式三:FBV+ModelForm+get_object_or_404的更多相关文章
- 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 ...
- 战争热诚的python全栈开发之路
从学习python开始,一直是自己摸索,但是时间不等人啊,所以自己为了节省时间,决定报个班系统学习,下面整理的文章都是自己学习后,认为重要的需要弄懂的知识点,做出链接,一方面是为了自己找的话方便,一方 ...
- python全栈开发之路
一.Python基础 python简介 python数据类型(数字\字符串\列表) python数据类型(元组\字典) python数据类型(集合) python占位符%s,%d,%r,%f prin ...
- 华为全栈AI技术干货深度解析,解锁企业AI开发“秘籍”
摘要:针对企业AI开发应用中面临的痛点和难点,为大家带来从实践出发帮助企业构建成熟高效的AI开发流程解决方案. 在数字化转型浪潮席卷全球的今天,AI技术已经成为行业公认的升级重点,正在越来越多的领域为 ...
- Python全栈开发之7、模块和几种常见模块以及format知识补充
一.模块的分类 Python流行的一个原因就是因为它的第三方模块数量巨大,我们编写代码不必从零开始重新造轮子,许多要用的功能都已经写好封装成库了,我们只要直接调用即可,模块分为内建模块.自定义的模块. ...
- 全网最全postman接口测试教程和接口项目实战~从入门到精通!!!
Postman实现接口测试内容大纲一览: 一.什么是接口?为什么需要接口? 接口指的是实体或者软件提供给外界的一种服务. 因为接口能使我们的实体或者软件的内部数据能够被外部进行修改.从而使得内 ...
- 云计算Docker全面项目实战(Maven+Jenkins、日志管理ELK、WordPress博客镜像)
2013年,云计算领域从此多了一个名词“Docker”.以轻量著称,更好的去解决应用打包和部署.之前我们一直在构建Iaas,但通过Iaas去实现统一功 能还是相当复杂得,并且维护复杂.将特殊性封装到 ...
- Orlion个人博客 | 全栈工程师之路-www.orlion.ga
自己用wordpress+bootstrap搭建了一个博客,网址http://www.orlion.ga,用来记录博主学习和成长,主要关注JAVA.LANMP.前端与客户端(Android).算法与数 ...
随机推荐
- win10,在桌面点击右键:显示设置和个性化,出现“该文件没有与之关联的应用来执行该操作,请安装应用,若已经安装应用,请在默认应用设置页面中创建关联”
参考:https://zhidao.baidu.com/question/2076100681854702028.html 1. WIN + R 打开运行,并输入 regedit,点击确定,进入注册表 ...
- HAL层分析
1. 安卓HAL模块基本 2. 定义hal层代码的5个特性 1)硬件抽象层具有与硬件的密切相关性. 2) 硬件抽象层具有与操作系统无关性. 3) 接口定义的功能应该包含硬件或者系统所需硬件支持的所有功 ...
- 使用vite创建vue3 遇到 process is not defined
今天新建项目遇到报错,查资料得出,需要在vite.config.js中添加代码如下 import { defineConfig } from 'vite' import vue from '@vite ...
- 存算分离实践:JuiceFS 在中国电信日均 PB 级数据场景的应用
01- 大数据运营的挑战 & 升级思考 大数据运营面临的挑战 中国电信大数据集群每日数据量庞大,单个业务单日量级可达到 PB 级别,且存在大量过期数据(冷数据).冗余数据,存储压力大:每个省公 ...
- 能快速构建和定制网络拓扑图的WPF开源项目-NodeNetwork
大家好,我是沙漠尽头的狼,今天介绍一个WPF开源项目-NodeNetwork,它可以帮助我们快速构建和定制网络拓扑图. 一.前言 在现代软件开发中,数据可视化和可交互性越来越受到关注.为了实现这一点, ...
- Windows 10 ltsc 2021 (2021/11/17更新版本)
Windows 10 Enterprise LTSC 2021 (x86) - DVD (Chinese-Simplified)文件:SW_DVD9_WIN_ENT_LTSC_2021_32BIT_C ...
- 【JS基础】ES6模块系统
export export 导出方式有两种,命名导出和默认导出. 命名导出还是默认导出都是都导出模块中内容的一种方式,可以混合使用. 个人理解:默认导出其实是导出了default别名变量. 一个模块只 ...
- 分享我通过 API 赚钱的思路
写在最前 我们经常看到非常多的 API 推荐,但又经常收藏到收藏夹里吃灰,仿佛收藏了就是用了. 很多时候没有用起来,可能是因为想不到某类 API 可以用来做什么或者能应用在哪里. 下面我将我思考的一些 ...
- vue中使用西瓜视频中引入自定义样式,绝对可以
首先配置sass-loader和raw-loader 方法,再vue-config.js中加上这一段代码 module.exports = { chainWebpack: config => { ...
- Host key verification failed的问题解决 (亲测有效)
一.描述 scp拷贝远程内容时失败,出现以下问题: 翻译: @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ ...