from flask import request
import math
def pages(counts,pageNum):
# counts:总共的条数,pageNum:每页显示的条数
# 进来判断在请求的url中是否含有page
# 1.不携带任何参数
if request.url.find("?")<0:
url=request.url+"?page="
# 2.携带其余参数
else:
# 是否携带page参数
# 不携带page参数
if request.url.find("page")<0:
url=request.url+"&page="
# 携带page参数
else:
url=request.url[0:request.url.rfind("=")+1]
# 计算总页数
pageCounts=math.ceil(counts/pageNum)
# 当前页码
currentPage=int(request.args.get("page") or 0)
# strs表示渲染的html代码
strs="<i>总 %s页</i>"%(pageCounts)
# 首页
strs+="<span><button type='button' class='btn btn-default' srcs=%s>首页</button>"%(url+str(0))
# 上一页
last=currentPage-1 if currentPage-1>0 else 0
strs+="<span><button type='button' class='btn btn-default' srcs=%s>上一页</button>"%(url+str(last))
# 计算每次显示的开始和结束页
start=currentPage-2 if currentPage-2> 0 else 0
end=start+4 if currentPage+4<pageCounts else pageCounts
# 中间页
for item in range(start,end):
if currentPage==item:
strs+="<span><button type='button' class='btn btn-default' style='color:red;' srcs=%s>%s</button>"%(url+str(item),item+1)
else:
strs+="<span><button type='button' class='btn btn-default' srcs=%s>%s</button>"%(url+str(item),item+1)
# 下一页
next=currentPage+1 if currentPage+1<pageCounts else pageCounts-1
strs+="<span><button type='button' class='btn btn-default' srcs=%s>下一页</button>"%(url+str(next))
# 尾页
strs+="<span><button type='button' class='btn btn-default' srcs=%s>尾页</button>"%(url+str(pageCounts-1))
# 限制[注意limit前的空格,否则sql语句报错]
limit=" limit "+str(currentPage*pageNum)+","+str(pageNum)
# 返回limit和页码
return {'limit':limit,'strs':strs}
分页
最新推荐文章于 2024-04-09 16:54:23 发布