Django实现基于类的分页功能
作者:︶举个栗子彡 发布时间:2022-04-06 21:49:03
标签:Django,分页
开发个人博客时往往避免不了分页功能的实现,实现方法大体上分为函数和类两种。本文基于类实现分页功能,以下是详细代码:
class Page:
page_num = 0
total_count = 0
tartype = ""
total_page = 0 # 总页数
per_page = 8 # 每页显示8篇文章
max_page = 11 # 每页最大展示页数选项
half_page = max_page // 2
category = "" # 标记该链接所属分类ID,首页默认为空
def __init__(self, page_num, total_count, tartype, category):
"""
初始化函数:接收页码数、总数据数,计算总页码数并过滤错误页码数据
:param page_num: 页码数
:param total_count: 总数据数
:param tartype: 分类值
:param category: 所属分类ID
"""
self.page_num = page_num
self.total_count = total_count
self.tartype = tartype
self.total_page, m = divmod(self.total_count, self.per_page) # 总页码数,余数为m
if category:
self.category = category
if m:
self.total_page += 1
if self.total_page < self.max_page:
self.max_page = self.total_page
self.half_page = self.max_page // 2
# 过滤错误get数据
if self.page_num > self.total_page:
self.page_num = self.total_page
elif self.page_num < 1:
self.page_num = 1
def data_start(self):
return (self.page_num - 1) * self.per_page
def data_end(self):
return self.page_num * self.per_page
def page_html(self):
# 计算页数选项
page_start = self.page_num - self.half_page
page_end = self.page_num + self.half_page
if page_start <= 1:
page_start = 1
page_end = self.max_page
if page_end >= self.total_page:
page_end = self.total_page
page_start = self.total_page - self.max_page + 1
# 计算上一页下一页选项
if self.page_num == 1:
last_page = self.page_num
next_page = self.page_num + 1
else:
if self.page_num == self.total_page:
last_page = self.page_num - 1
next_page = self.page_num
else:
last_page = self.page_num - 1
next_page = self.page_num + 1
print(self.category)
html_str_list = []
html_str_list.append('<li><a href="/{}/?page={}{}" >«</a></li>'.format(self.tartype, last_page, self.category))
for i in range(page_start, page_end + 1):
if i == self.page_num:
tmp = '<li><a class="active" href="/{}/?page={}{}" >{}</a></li>'.format(self.tartype, i, self.category, i)
html_str_list.append(tmp)
continue
tmp = '<li><a href="/{}/?page={}{}" >{}</a></li>'.format(self.tartype, i, self.category, i)
html_str_list.append(tmp)
html_str_list.append('<li><a href="/{}/?page={}{}" >»</a></li>'.format(self.tartype, next_page, self.category))
page_html = "".join(html_str_list)
return page_html
通过修改per_page、max_page控制每页展示的文章数和分页模块展示的最大页码数。
实现思路:创建page类对象,传入参数为page_num(当前页码数)、total_count(总文章数)、tartype(分类值)、category(所属分类ID)【注:tartpe用于区分index页还是category页,category为查询的分类ID,index页时值为空。可以根据自己要实现的功能进行修改】构造函数会计算出总页码数并过滤掉错误数据。需要实现某功能是直接调用类方法即可。
类方法:data_start()计算出当前页的文章的起始索引值
data_end()计算出当前页的文章的起始索引值
page_html()返回分页模块的html代码,可直接render到前端。
实现效果:
文章较少时:
文章较多时:
来源:https://www.jhxblog.cn/article/?articleid=5


猜你喜欢
- 这是不久前写的一个分页存储过程,可应用于SQL Server 2005上面: if object_ID('[proc_SelectF
- 直接给出例子说明:cs = conn.cursor()img_ids = [1,2,3]sql = "select img_url
- 有的时候需要对python程序内存占用进行监控,这个时候可以用到psutil库,Anaconda中是自带的,如果import出错,可以用pi
- 一、引言Windows Communication Foundation(WCF)是Microsoft为构建面向服务的应用程序而提供的统一编
- springboot配置文件抽离,便于服务器读取对应配置文件,避免项目频繁更改配置文件,影响项目的调试与发布1.创建统一配置中心项目coni
- 本文实例介绍了如何使用ASP代码来读写注册表,呵呵厉害吧! 一个例子: <%Dim ReadComputerNam
- 1、 变量及其作用域:变量分为“全局变量”和“局部变量”,“全局变量”申明在函数外部,可供所有函数使用,而“局部变量”申明在函数体内部,只能
- 大致介绍拖拽改变元素大小是在模拟拖拽上增加了一些功能拖拽改变元素大小原理首先这个方块得知道我们想要改变这个它的大小,所以我给它设定一个范围,
- 要调用RPC接口,python提供了一个框架grpc,这是google开源的rpc相关文档:https://grpc.io/docs/tut
- 仔细观察下面两个python程序,代码一模一样,但是运行的结果却不同,就是因为最后一行return缩进的不同def powersum(pow
- 一、TensorFlow介绍1、简介 TensorFlow是一个基于数据流编程(dataflow programming)的符号数学系统,
- tensorflow模型保存为saver = tf.train.Saver()函数,saver.save()保存模型,代码如下:import
- 介绍RANGE分区基于一个给定的连续区间范围,早期版本RANGE主要是基于整数的分区。在5.7版本中DATE、DATETIME列也可以使用R
- Go语言内置int转string至少有3种方式:fmt.Sprintf("%d",n)strconv.Itoa(n)st
- 获取首页元素信息:目标 test_URL:http://www.xxx.com.cn/首先检查元素,a 标签下是我们需要爬取得链接,通过获取
- 当由where子句指定的搜索条件指向另一张表时,就需要使用子查询或嵌套查询。1 子查询子查询是一个嵌套在select、insert、upda
- 1. 简介 追踪某些软件运行时所发生事件的方法, 可以在代码中调用日志中某些方法来记录发生的事情一个事件可以用一个可包含可选变量数
- 通用load/write方法手动指定选项Spark SQL的DataFrame接口支持多种数据源的操作。一个DataFrame可以进行RDD
- 说在前面和word的文本相比PDF更类似于一张张图片,图上放着一个个文字。对其的解析是将图片上的文字提取到text文件中,方便之后的分析。添
- Keras运行迭代一定代数以后,速度越来越慢,经检查是因为在循环迭代过程中增加了新的计算节点,导致计算节点越来越多,内存被占用完,速度变慢。