1.类目管理列表实现
当管理员进入后台管理后,点击类目管理,向服务器发出请求
path('admin/type_list/',viewsAdmin.type_list),
# 处理商品分类管理列表请求
def type_list(request):
# 读取分页页码
try:
ym = request.GET["ym"]
except:
ym = 1
# 查询所有商品分类
types = Type.objects.all().order_by("id").values()
# 将该分类的商品信息进行分页处理,每页显示5条记录
pag = paginator.Paginator(types, 10)
# 根据当前页码获取当前分页信息
pageInfo = pag.get_page(ym)
# 获取当前页的商品列表信息
types = pageInfo.object_list
# 获取总页码数
yms = pag.page_range
return render(request, "adminTemp/type_list.html",
{"types": types, "page": pageInfo, "yms": yms})
<!DOCTYPE html>
<html>
<head>
<title>类目列表</title>
{% load static %}
<meta charset="utf-8"/>
<link rel="stylesheet" href="{% static 'css/bootstrap.css' %}"/>
<link rel="stylesheet" href="{% static 'css/page.css' %}"/>
</head>
<body>
<div class="container-fluid">
{% include "adminTemp/header.html" %}
<br>
<div>
<form class="form-inline" method="post" action="/admin/type_add/">
{% csrf_token %}
<input type="text" class="form-control" id="input_name" name="name" placeholder="输入类目名称" required="required"
style="width: 500px">
<input type="submit" class="btn btn-warning" value="添加类目"/>
</form>
</div>
<br/>
{% if msg %}
<div class="alert alert-success">{{ msg }}</div>
{% endif %}
{% if failMsg %}
<div class="alert alert-danger">{{ failMsg }}</div>
{% endif %}
<br>
<table class="table table-bordered table-hover">
<tr>
<th width="5%">ID</th>
<th width="10%">名称</th>
<th width="10%">操作</th>
</tr>
{% for t in types %}
<tr>
<td><p>{{ t.id }}</p></td>
<td><p>{{ t.name }}</p></td>
<td>
<a class="btn btn-primary" href="/admin/type_edit/?id={{ t.id }}&name={{ t.name }}">修改</a>
<a class="btn btn-danger" href="/admin/type_delete/?id={{ t.id }}">删除</a>
</td>
</tr>
{% endfor %}
</table>
<!-- 显示页码导航栏 -->
<div id="nav" align="center">
<!-- 上一页 -->
<!-- 判断当前页是否有上一页,如果有上一页则显示上一页的按钮,否则就不显示上一页 -->
{% if page.has_previous %}
<a href="/admin/type_list/?ym={{ page.previous_page_number }}" class="up_page">上一页</a>
{% endif %}
<!-- 页码 -->
{% for ym in yms %}
{% if page.number == ym %}
<a href="/admin/type_list/?ym={{ ym }}" class="p_page c_page">{{ ym }}</a>
{% else %}
<a href="/admin/type_list/?ym={{ ym }}" class="p_page">{{ ym }}</a>
{% endif %}
{% endfor %}
<!-- 下一页 -->
{% if page.has_next %}
<a href="/admin/type_list/?ym={{ page.next_page_number }}" class="do_page">下一页</a>
{% endif %}
</div>
<br>
</div>
</body>
</html>
2.添加类目功能
当管理员需要添加分类时,点击添加类目按钮,向服务器发送请求,将新的分类添加至数据库
path('admin/type_add/',viewsAdmin.type_add),
# 添加分类请求
def type_add(request):
name = request.POST["name"]
Type.objects.create(name=name)
return redirect(type_list)
3.修改类目功能
当管理员需要修改分类时,点击修改按钮,跳转至修改页面
path('admin/type_edit/',viewsAdmin.type_edit),
# 修改分类请求
def type_edit(request):
id = request.GET["id"]
name = request.GET["name"]
return render(request, "adminTemp/type_edit.html", {"id": id, "name": name})
<!DOCTYPE html>
<html>
<head>
<title>类目编辑</title>
{% load static %}
<meta charset="utf-8"/>
<link rel="stylesheet" href="{% static 'css/bootstrap.css' %}"/>
</head>
<body>
<div class="container-fluid">
{% include "adminTemp/header.html" %}
<br><br>
<form class="form-horizontal" action="/admin/edit/" method="post">
{% csrf_token %}
<input type="hidden" name="id" value="{{ id }} ">
<div class="form-group">
<label for="input_name" class="col-sm-1 control-label">类目名称</label>
<div class="col-sm-6">
<input type="text" class="form-control" id="input_name" name="name" value="{{ name }}" required="required">
</div>
</div>
<div class="form-group">
<div class="col-sm-offset-1 col-sm-10">
<button type="submit" class="btn btn-success">提交修改</button>
</div>
</div>
</form>
<span style="color:red;"></span>
</div>
</body>
</html>
当管理员更新分类内容后,点击提交修改按钮
path('admin/edit/',viewsAdmin.edit),
# 完成修改分类请求
def edit(request):
id=request.POST["id"]
name=request.POST["name"]
type=Type.objects.filter(id=id)
type.update(name=name)
return redirect(type_list)
4.删除类目功能
当管理员删除某一个分类时,点击删除按钮
path('admin/type_delete/',viewsAdmin.type_delete),
# 删除分类请求
def type_delete(request):
id=request.GET["id"]
type=Type.objects.get(id=id)
type.delete()
return redirect(type_list)