一个自定制的分页器

直接上代码吧,仅做记录以后可以直接拿着用。因为这是一个Django框架的所以就。。。。
views下的pager.py

from django.utils.safestring import mark_safe

class Pagination(object):
    def __init__(self,totalCount,currentPage,perPageItemNum=10,maxPageNum=7):
        # 数据总个数
        self.total_count = totalCount
        # 当前页
        try:
            v = int(currentPage)
            if v <= 0:
               v = 1
            self.current_page = v
        except Exception as e:
            self.current_page = 1
        # 每页显示的行数
        self.per_page_item_num = perPageItemNum
        # 最多显示页面
        self.max_page_num = maxPageNum
    #展示每页第一条数据的索引
    def start(self):
        return (self.current_page-1) * self.per_page_item_num
    #展示每页最后一条数据的索引
    def end(self):
        return self.current_page * self.per_page_item_num
    @property  #加上这个以后运行这个函数时      num_pages就可以直接使用了,不用加'()'了,这个函数返回的是页码
    def num_pages(self):
        """
        总页数
        :return:
        """
        # 666
        # 10
        #这个divmod展示的是总数据除以每页展示的数据的值和余数
        a,b = divmod(self.total_count,self.per_page_item_num)#print(divmod(10,3))  #divmod展示的是10除以3的值和余数
        #如果没有余数返回一个页数的整值
        if b == 0:
            return a
        #如果有余数返回的是页码值是a+1
        return a+1

    def pager_num_range(self):
        # self.num_pages()
        # self.num_pages
        # 当前页
        #self.current_page
        # 最多显示的页码数量 11
        #self.per_pager_num
        # 总页数
        # self.num_pages
        #如果上个函数的出的页码小于最大的显示页码,返回一个列表是1到总页码
        if self.num_pages < self.max_page_num:
            return range(1,self.num_pages+1)
        # 总页数特别多 5
        #当总页码大于每页显示的最大页码数时,算出中间的页码值part
        part = int(self.max_page_num/2)
        #在当前页码小于part时,返回一个列表是第一页到最大页码数
        if self.current_page <= part:
            return range(1,self.max_page_num+1)
        #当当前页码+中间页码大于总页码时
        if (self.current_page + part) > self.num_pages:
            return range(self.num_pages-self.max_page_num+1,self.num_pages+1)
        return range(self.current_page-part,self.current_page+part+1)

    def page_str(self):
        page_list = []

        first = "<li><a href='/index2?p=1'>首页</a></li>"
        page_list.append(first)

        if self.current_page == 1:
            prev = "<li><a href='#'>上一页</a></li>"
        else:
            prev = "<li><a href='/index2?p=%s'>上一页</a></li>" %(self.current_page-1,)
        page_list.append(prev)
        for i in self.pager_num_range():
            if i == self.current_page:
                temp = "<li class='active'><a href='/index2?p=%s'>%s</a></li>" %(i,i)
            else:
                temp = "<li><a href='/index2?p=%s'>%s</a></li>" % (i, i)
            page_list.append(temp)

        if self.current_page == self.num_pages:
            nex = "<li><a href='#'>下一页</a></li>"
        else:
            nex = "<li><a href='/index2?p=%s'>下一页</a></li>" % (self.current_page + 1,)
        page_list.append(nex)

        last = "<li><a href='/index2?p=%s'>尾页</a></li>" %(self.num_pages,)
        page_list.append(last)
        #mark_safe是可以生成HTML代码的
        return mark_safe(''.join(page_list))


views下的index2函数


from django.shortcuts import render

from app.views.pager import Pagination


user_list=[]
for i in range(1,900):
    temp = {'name':'root'+str(i),'age':i}
    user_list.append(temp)


def index2(request):

    current_page = request.GET.get('p')
    page_obj = Pagination(666,current_page)

    data_list = user_list[page_obj.start():page_obj.end()]
    return render(request,'index2.html',{'data':data_list,'page_obj':page_obj})

这个是index2.html的代码,这个里面是加了样式的

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <link rel="stylesheet" href="/static/plugins/bootstrap/css/bootstrap.css">

</head>
<body>
    <ul>
        {% for row in data %}
            <li>{{ row.name }}-{{ row.age }}</li>
        {% endfor %}
    </ul>

    <hr/>
    <nav aria-label="...">
        <ul class="pagination pagination-sm">
            {{ page_obj.page_str }}
        </ul>
    </nav>
   
    <div style="height: 300px;"></div>
</body>
</html>

其他的urls和setting以及一些配置自己配置好就行了,散会!!!!!

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ZhaoXuWen23

你的鼓励是我的动力,持续更新中

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值