09 django管理系统 - 管理员管理 - 管理员列表

通过部门管理的增删改查,大概了解了django的过程,下面通过管理员模块来复习一遍。

前期准备

1 创建管理员的Model类

python 复制代码
# 创建管理员表
class Admin(models.Model):
    name = models.CharField(max_length=100)
    password = models.CharField(max_length=100)
    sex_choice = (
        ('1', '男'),
        ('2', '女')
    )
    sex = models.CharField(max_length=2, choices=sex_choice)

2 执行以下语句,把表映射到数据库中

manage.py@MS > makemigrations

manage.py@MS > migrate

效果如下:

下面开始进行管理员列表模块的实现

首先是在模板文件里,新增管理员模块入口

html 复制代码
        <div class="collapse navbar-collapse" id="bs-example-navbar-collapse-1">
            <ul class="nav navbar-nav">
                <li class="active"><a href="/dept/list/">部门管理</a></li>
            </ul>

            <ul class="nav navbar-nav">
                <li class="active"><a href="/admin/list/">管理员</a></li>
            </ul>

效果如下:

添加URL路径

python 复制代码
urlpatterns = [
    # 部门管理
    path("dept/list/", dept.dept_list),
    path("dept/add/", dept.dept_add),
    path("dept/<int:nid>/edit_detail/", dept.dept_editdetail),
    path("dept/<int:nid>/delete/", dept.dept_delete),
    path("dept/search/", dept.dept_search),
    
    # 管理员管理
    path("admin/list/", admin.admin_list),

]

去my_views目录下创建admin.py,并新建admin_list()方法

python 复制代码
from django.http import HttpResponse


def admin_list(request):
    return HttpResponse("admin_list is ok")

测试成功,效果如下:

我们让他返回一个html页面

html 复制代码
from django.http import HttpResponse
from django.shortcuts import render


def admin_list(request):
    # return HttpResponse("admin_list is ok")
    return render(request, 'admin_list.html')

新建admin_list.html页面,继承base.html

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

{% block content %}
    
{% endblock %}

接着去函数里去遍历admin_list里的数据,我先用navicat随便创建2条数据

接着我们去修改admin_list()的业务逻辑

python 复制代码
from django.shortcuts import render

from app01 import models


def admin_list(request):
    # return HttpResponse("admin_list is ok")
    # 查询所有的数据
    queryset = models.Admin.objects.using("default").all()
    context = {
        "queryset": queryset
    }
    return render(request, 'admin_list.html', context)

接着我们去admin_list.html里去实现数据展示,通过表单获取数据,然后进行遍历

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

{% block content %}
    <div class="container-fluid">
        <div style="margin-bottom: 10px" class="clearfix">
            <div class="panel panel-default">

                <div class="panel-body">
                    <div style="float: left">
                        <p>管理员列表</p>
                    </div>
                    <!-- Table -->
                    <table class="table">
                        <thead>
                        <tr>
                            <th>ID</th>
                            <th>name</th>
                            <th>password</th>
                            <th>sex</th>
                            <th>操作</th>
                        </tr>
                        </thead>
                        <tbody>
                        {% for obj in queryset %}
                            <tr>
                                <td>{{ obj.id }}</td>
                                <td>{{ obj.name }}</td>
                                <td>{{ obj.password }}</td>
                                <td>{{ obj.get_sex_display }}</td>

                                <td>
                                    <a class="btn btn-success" href="#" role="button">编辑管理员</a>
                                    <a class="btn btn-danger" href="#" role="button">删除管理员</a>
                                </td>
                            </tr>

                        {% endfor %}
                        </tbody>
                    </table>
                    {% if error %}
                        <div style="color: red;">
                            {{ error }}
                        </div>
                    {% endif %}
                </div>
            </div>
        </div>

    </div>
{% endblock %}

效果如下:

相关推荐
申阳几秒前
Day 3:01. 基于Nuxt开发个人呢博客项目-初始化项目
前端·后端·程序员
铁锹少年2 分钟前
当多进程遇上异步:一次 Celery 与 Async SQLAlchemy 的边界冲突
分布式·后端·python·架构·fastapi
梨轻巧4 分钟前
pyside6常用控件:QCheckBox() 单个复选框、多个复选框、三态模式
python
寒秋丶10 分钟前
Milvus:集合(Collections)操作详解(三)
数据库·人工智能·python·ai·ai编程·milvus·向量数据库
寒秋丶12 分钟前
Milvus:Schema详解(四)
数据库·人工智能·python·ai·ai编程·milvus·向量数据库
曾经的三心草16 分钟前
springcloud二-Seata3- Seata各事务模式
后端·spring·spring cloud
梨轻巧17 分钟前
pyside6常用控件:QComboBox() 下拉菜单
python
王中阳Go20 分钟前
又整理了一场真实Golang面试复盘!全是高频坑+加分话术,面试遇到直接抄
后端·面试·go
JavaGuide24 分钟前
今年小红书后端开出了炸裂的薪资!
后端·面试
嵌入式-老费27 分钟前
自己动手写深度学习框架(快速学习python和关联库)
开发语言·python·学习