"""
自定义的分页组件,以后如果想要使用这个分页组件,你需要做如下几件事:
在视图函数中:
def pretty_list(request):
# 1.根据自己的情况去筛选自己的数据
queryset = models.PrettyNum.objects.all()
# 2.实例化分页对象
page_object = Pagination(request, queryset)
context = {
"queryset": page_object.page_queryset, # 分完页的数据
"page_string": page_object.html() # 生成页码
}
return render(request, 'pretty_list.html', context)
在HTML页面中
{% for obj in queryset %}
{{obj.xx}}
{% endfor %}
<ul class="pagination">
{{ page_string }}
</ul>
"""
from django.utils.safestring import mark_safe
class Pagination(object):
def __init__(self, request, queryset, page_size=10, page_param="page", plus=5):
"""
:param request: 请求的对象
:param queryset: 符合条件的数据(根据这个数据给他进行分页处理)
:param page_size: 每页显示多少条数据
:param page_param: 在URL中传递的获取分页的参数,例如:/etty/list/?page=12
:param plus: 显示当前页的 前或后几页(页码)
"""
from django.http.request import QueryDict
import copy
query_dict = copy.deepcopy(request.GET)
query_dict._mutable = True
self.query_dict = query_dict
self.page_param = page_param
page = request.GET.get(page_param, "1")
if page.isdecimal():
page = int(page)
else:
page = 1
self.page = page
self.page_size = page_size
self.start = (page - 1) * page_size
self.end = page * page_size
self.page_queryset = queryset[self.start:self.end]
total_count = queryset.count()
total_page_count, div = divmod(total_count, page_size)
if div:
total_page_count += 1
self.total_page_count = total_page_count
self.plus = plus
def html(self):
# 计算出,显示当前页的前5页、后5页
if self.total_page_count <= 2 * self.plus + 1:
# 数据库中的数据比较少,都没有达到11页。
start_page = 1
end_page = self.total_page_count
else:
# 数据库中的数据比较多 > 11页。
# 当前页<5时(小极值)
if self.page <= self.plus:
start_page = 1
end_page = 2 * self.plus + 1
else:
# 当前页 > 5
# 当前页+5 > 总页面
if (self.page + self.plus) > self.total_page_count:
start_page = self.total_page_count - 2 * self.plus
end_page = self.total_page_count
else:
start_page = self.page - self.plus
end_page = self.page + self.plus
# 页码
page_str_list = []
self.query_dict.setlist(self.page_param, [1])
page_str_list.append('<li><a href="?{}">首页</a></li>'.format(self.query_dict.urlencode()))
# 上一页
if self.page > 1:
self.query_dict.setlist(self.page_param, [self.page - 1])
prev = '<li><a href="?{}">上一页</a></li>'.format(self.query_dict.urlencode())
else:
self.query_dict.setlist(self.page_param, [1])
prev = '<li><a href="?{}">上一页</a></li>'.format(self.query_dict.urlencode())
page_str_list.append(prev)
# 页面
for i in range(start_page, end_page + 1):
self.query_dict.setlist(self.page_param, [i])
if i == self.page:
ele = '<li class="active"><a href="?{}">{}</a></li>'.format(self.query_dict.urlencode(), i)
else:
ele = '<li><a href="?{}">{}</a></li>'.format(self.query_dict.urlencode(), i)
page_str_list.append(ele)
# 下一页
if self.page < self.total_page_count:
self.query_dict.setlist(self.page_param, [self.page + 1])
prev = '<li><a href="?{}">下一页</a></li>'.format(self.query_dict.urlencode())
else:
self.query_dict.setlist(self.page_param, [self.total_page_count])
prev = '<li><a href="?{}">下一页</a></li>'.format(self.query_dict.urlencode())
page_str_list.append(prev)
# 尾页
self.query_dict.setlist(self.page_param, [self.total_page_count])
page_str_list.append('<li><a href="?{}">尾页</a></li>'.format(self.query_dict.urlencode()))
search_string = """
<li>
<form style="float: left;margin-left: -1px" method="get">
<input name="page"
style="position: relative;float:left;display: inline-block;width: 80px;border-radius: 0;"
type="text" class="form-control" placeholder="页码">
<button style="border-radius: 0" class="btn btn-default" type="submit">跳转</button>
</form>
</li>
"""
page_str_list.append(search_string)
page_string = mark_safe("".join(page_str_list))
return page_string
没有合适的资源?快使用搜索试试~ 我知道了~
温馨提示
基于Python+Django+MySQL的学生信息管理系统,带用户登录、注册,基本的学生信息的增加、修改、删除、查询和班级添加修改等功能,用Pycharm导入,安装依赖包,配置好数据库就可以正常运行了,里面的代码都含有注释,结构简单,清晰易懂,看一下就会了,可以基于这个来做二次开发都行,有需要可以私聊 1) 操作系统:Windows 2) 数据库系统:Mysql 3) 开发平台及工具:PyCharm, Django 4) 数据库:MySQL 5) 其他软件:Navicat数据库连接工具
资源推荐
资源详情
资源评论
收起资源包目录
基于Python+Django+MySQL的学生信息管理系统 (224个子文件)
bootstrap.css 143KB
bootstrap.min.css 119KB
bootstrap-theme.css 25KB
bootstrap-datepicker3.standalone.css 23KB
bootstrap-theme.min.css 23KB
bootstrap-datepicker3.css 22KB
bootstrap-datepicker3.standalone.min.css 21KB
bootstrap-datepicker3.min.css 21KB
bootstrap-datepicker.standalone.css 18KB
bootstrap-datepicker.css 17KB
bootstrap-datepicker.standalone.min.css 16KB
bootstrap-datepicker.min.css 15KB
glyphicons-halflings-regular.eot 20KB
.gitignore 190B
user_add.html 3KB
admin_list.html 2KB
layout.html 2KB
user_list.html 2KB
login.html 2KB
register.html 2KB
user_model_form_add.html 2KB
depart_list.html 1KB
change.html 872B
user_edit.html 869B
depart_edit.html 806B
depart_add.html 741B
error.html 172B
school.iml 1KB
code.jpg 8KB
echarts.js 3.13MB
echarts.min.js 989KB
jquery-3.6.0.min.js 87KB
bootstrap.js 74KB
bootstrap-datepicker.js 57KB
bootstrap.min.js 39KB
bootstrap-datepicker.min.js 33KB
bootstrap-datepicker.bn.min.js 1KB
bootstrap-datepicker.kh.min.js 1KB
bootstrap-datepicker.si.min.js 988B
bootstrap-datepicker.ka.min.js 970B
bootstrap-datepicker.km.min.js 945B
bootstrap-datepicker.hi.min.js 944B
bootstrap-datepicker.ta.min.js 934B
bootstrap-datepicker.th.min.js 833B
bootstrap-datepicker.rs.min.js 817B
bootstrap-datepicker.el.min.js 764B
bootstrap-datepicker.hy.min.js 757B
bootstrap-datepicker.ru.min.js 731B
bootstrap-datepicker.uk.min.js 722B
bootstrap-datepicker.ar.min.js 714B
bootstrap-datepicker.ar-tn.min.js 704B
bootstrap-datepicker.uz-cyrl.min.js 703B
bootstrap-datepicker.tg.min.js 700B
bootstrap-datepicker.fa.min.js 670B
bootstrap-datepicker.rs-latin.min.js 662B
bootstrap-datepicker.mk.min.js 657B
bootstrap-datepicker.sr.min.js 651B
bootstrap-datepicker.kk.min.js 649B
bootstrap-datepicker.mn.min.js 638B
bootstrap-datepicker-en-CA.min.js 636B
bootstrap-datepicker.bg.min.js 615B
bootstrap-datepicker.zh-CN.min.js 613B
bootstrap-datepicker.kr.min.js 575B
bootstrap-datepicker.zh-TW.min.js 566B
bootstrap-datepicker.lt.min.js 565B
bootstrap-datepicker.he.min.js 563B
bootstrap-datepicker.bm.min.js 562B
bootstrap-datepicker.pl.min.js 552B
bootstrap-datepicker.vi.min.js 551B
bootstrap-datepicker.hu.min.js 541B
bootstrap-datepicker.et.min.js 537B
bootstrap-datepicker.cs.min.js 536B
bootstrap-datepicker.fr.min.js 536B
bootstrap-datepicker.ko.min.js 532B
bootstrap-datepicker.az.min.js 531B
bootstrap-datepicker.tk.min.js 530B
bootstrap-datepicker.fi.min.js 528B
bootstrap-datepicker.eu.min.js 528B
bootstrap-datepicker.lv.min.js 526B
bootstrap-datepicker.it.min.js 525B
bootstrap-datepicker.nl-BE.min.js 522B
bootstrap-datepicker.sq.min.js 518B
bootstrap-datepicker.en-GB.min.js 518B
bootstrap-datepicker.en-CA.min.js 518B
bootstrap-datepicker.en-IE.min.js 518B
bootstrap-datepicker.de.min.js 517B
bootstrap-datepicker.en-AU.min.js 517B
bootstrap-datepicker.en-NZ.min.js 517B
bootstrap-datepicker.en-ZA.min.js 517B
bootstrap-datepicker.uz-latn.min.js 516B
bootstrap-datepicker.oc.min.js 515B
bootstrap-datepicker.no.min.js 515B
bootstrap-datepicker.eo.min.js 515B
bootstrap-datepicker.da.min.js 514B
bootstrap-datepicker.nl.min.js 513B
bootstrap-datepicker.es.min.js 513B
bootstrap-datepicker.ca.min.js 513B
bootstrap-datepicker.fr-CH.min.js 512B
bootstrap-datepicker.br.min.js 510B
bootstrap-datepicker.it-CH.min.js 506B
共 224 条
- 1
- 2
- 3
资源评论
跳舞的皮埃尔
- 粉丝: 6997
- 资源: 19
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功