ToB企服应用市场:ToB评测及商务社交产业平台
标题:
Django中封装分页组件
[打印本页]
作者:
冬雨财经
时间:
2022-9-16 17:16
标题:
Django中封装分页组件
Django中封装分页组件
(1) 定义Paginator类
from django.utils.safestring import mark_safe
class Paginator(object):
"""
初始化参数说明:
request:请求对象
data:查询到的符合条件的数据
search_data:搜索框收索的关键字,解决收索情况下分页的BUG
page_parm:分页请求的参数名称,例如:http://127.0.0.1:8000/phonenum/list/?page=2&q=
page_size:每页显示的数据量
plus:当前页分页按钮的两边显示的按钮数量
"""
def __init__(self, request, data, search_data, page_parm="page", page_size=15, plus=5):
page = request.GET.get(page_parm, "")
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.data = data[self.start:self.end]
total_count = data.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
self.search_data = search_data
self.page_parm = page_parm
# 生成html标签
def Html(self):
if self.total_page_count <= 2 * self.plus + 1:
start_page = 1
end_page = self.total_page_count
else:
if self.page < self.plus:
start_page = 1
end_page = 2 * self.plus
else:
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 = []
# 首页
first_page = '<li><a target="_blank" href="https://www.cnblogs.com/?{}={}&q={}">首页</a></li>'.format(self.page_parm, 1, self.search_data)
page_str_list.append(first_page)
# 上一页
if self.page > 1:
pre = '<li><a target="_blank" href="https://www.cnblogs.com/?{}={}&q={}">上一页</a></li>'.format(self.page_parm, self.page - 1, self.search_data)
else:
pre = '<li><a target="_blank" href="https://www.cnblogs.com/?{}={}&q={}">上一页</a></li>'.format(self.page_parm, 1, self.search_data)
page_str_list.append(pre)
for i in range(start_page, end_page + 1):
if i == self.page:
ele = '<li ><a target="_blank" href="https://www.cnblogs.com/?{}={}&q={}">{}</a></li>'.format(self.page_parm, i, self.search_data,
i)
else:
ele = '<li><a target="_blank" href="https://www.cnblogs.com/?{}={}&q={}">{}</a></li>'.format(self.page_parm, i, self.search_data, i)
page_str_list.append(ele)
# 下一页
if self.page < self.total_page_count:
next = '<li><a target="_blank" href="https://www.cnblogs.com/?{}={}&q={}">下一页</a></li>'.format(self.page_parm, self.page + 1, self.search_data)
else:
next = '<li><a target="_blank" href="https://www.cnblogs.com/?{}={}&q={}">下一页</a></li>'.format(self.page_parm, self.total_page_count,
self.search_data)
page_str_list.append(next)
# 尾页
last_page = '<li><a target="_blank" href="https://www.cnblogs.com/?{}={}&q={}">尾页</a></li>'.format(self.page_parm, self.total_page_count,
self.search_data)
page_str_list.append(last_page)
search_string = """
<form method="get">
<input type="text" placeholder="请输入页码" name="{}">
<button type="submit">跳转</button>
</form>
""".format(self.page_parm)
page_str_list.append(search_string)
page_string = mark_safe("".join(page_str_list))
return page_string
复制代码
(2) 导入Paginator类,传入参数如下所示
def phoneNum_list(request):
"""靓号列表"""
data_dict={}
search_data=request.GET.get("q","")
if search_data:
data_dict["phone_num__contains"]=search_data
# 分页
data = PrettyPhoneNum.objects.filter(**data_dict).order_by("level")
page_object=Paginator(request,data,search_data) # 其他三个参数根据需求调整
context={
"data": page_object.data,
"search_data": search_data,
"page_string": page_object.Html()
}
return render(request,"phonenum_list.html",context)
复制代码
data为查询到的分页后的数据,search_data为收索的关键字,返回用于搜索框保留上次搜索的内容,page_string为分页按钮
(3) 在前端显示分页按钮
<nav aria-label="...">
<ul >
{{ page_string }}
</ul>
</nav>
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/)
Powered by Discuz! X3.4