• Django【进阶】分页功能Pagination


    项目中,我们需要很多非业务逻辑的功能,例如分页功能,而且此类功能移植性很好,可以在不同的项目中使用,所以整理好这些功能会一定程度上提高开发效率,下面是分页功能代码,使用时,可单独放在utils目录
    """
    使用方法:
    
    from utils.page import Pagination
    def users(request):
        current_page = int(request.GET.get('page',1))
    
        total_item_count = models.UserInfo.objects.all().count()
        # page_obj = Pagination(current_page,total_item_count,request.path_info)  
        # request.path_info,当前请求的页面,也可以直接把请求页面写上,如下
        page_obj = Pagination(current_page,total_item_count,'/users.html')
    
        user_list = models.UserInfo.objects.all()[page_obj.start:page_obj.end]
    
        return render(request,'users.html',{'user_list':user_list,'page_html':page_obj.page_html()})
    
    
    """
    
    
    from django.utils.safestring import mark_safe
    
    class Pagination(object):
    
        def __init__(self,current_page,total_item_count,base_url,per_page_count=10,show_pager_count=11):
            """
            :param current_page:  当前页
            :param total_item_count: 数据库数据总条数
            :param base_url: 分页前缀URL
            :param per_page_count:   每页显示数据条数
            :param show_pager_count: 对多显示的页码
            """
            self.current_page = current_page
            self.total_item_count = total_item_count
            self.base_url = base_url
            self.per_page_count = per_page_count
            self.show_pager_count = show_pager_count
    
            max_pager_num, b = divmod(total_item_count, per_page_count)
            if b:
                max_pager_num += 1
            self.max_pager_num = max_pager_num
    
        @property
        def start(self):
            """
    
            :return:
            """
            return (self.current_page-1)* self.per_page_count
    
        @property
        def end(self):
            """
    
            :return:
            """
            return self.current_page * self.per_page_count
    
        def page_html(self):
            """
    
            :return:
            """
            page_list = []
    
            if self.current_page == 1:
                prev = ' <li><a href="#">上一页</a></li>'
            else:
                prev = ' <li><a href="%s?page=%s">上一页</a></li>' % (self.base_url,self.current_page - 1,)
            page_list.append(prev)
    
            half_show_pager_count = int(self.show_pager_count / 2)
    
            # 数据特别少,15条数据=2页
            if self.max_pager_num < self.show_pager_count:
                # 页码小于11
                pager_start = 1
                pager_end = self.max_pager_num + 1
            else:
                if self.current_page <= half_show_pager_count:
                    pager_start = 1
                    pager_end = self.show_pager_count + 1
                else:
                    if self.current_page + half_show_pager_count > self.max_pager_num:
                        pager_start = self.max_pager_num - self.show_pager_count + 1
                        pager_end = self.max_pager_num + 1
                    else:
                        pager_start = self.current_page - half_show_pager_count
                        pager_end = self.current_page + half_show_pager_count + 1
    
            for i in range(pager_start, pager_end):
                if i == self.current_page:
                    tpl = ' <li class="active"><a href="%s?page=%s">%s</a></li>' % (self.base_url,i, i,)
                else:
                    tpl = ' <li><a href="%s?page=%s">%s</a></li>' % (self.base_url,i, i,)
                page_list.append(tpl)
    
            if self.current_page == self.max_pager_num:
                nex = ' <li><a href="#">下一页</a></li>'
            else:
                nex = ' <li><a href="%s?page=%s">下一页</a></li>' % (self.base_url,self.current_page + 1,)
            page_list.append(nex)
    
            return mark_safe(''.join(page_list)
    

      

     
     
    应用:
     
    创建300条数据
     
    页面显示
     
    用get请求发送页码(get请求,直接在url后面加上"?page=n"就好了)
     
    调用上面的页码类,写好视图函数
     
    前端页面很简单就能显示出来页码
     

     
    思路:
    显示所有——按页显示(每页的起始结束项)——显示页码——当前页样式——上页下页——显示十个页码(当前页前后各五个)——页码前后极限处理

     
  • 相关阅读:
    mysql 索引
    redis持久化
    redis发布订阅
    django 信号
    paramiko模块
    23种设计模式python实现
    几种浏览器存储数据的方式
    关于传参
    对字符串里的四则运算进行计算2020/10/12
    动手动脑2020/10/9
  • 原文地址:https://www.cnblogs.com/lucaq/p/7587464.html
Copyright © 2020-2023  润新知