zoukankan      html  css  js  c++  java
  • python django 之 django自定制分页

    1. 自定制的分页模块
      #!/usr/bin/env python3
      
      # V1.1 解决问题:
      #   1). p 参数 为 负数 与 p 参数查过总页数时报错的问题
      
      # V1.2 解决的问题:
      #   1). 点击分页无法, get 其他参数的问题
      
      
      class  PageInfo(object):
          def __init__(self, current_page,per_page_num, all_count, base_url, get_url='' , page_range=9):
              """
              :param current_page: 当前页
              :param per_page_num: 每页显示的数据的条数
              :param all_count: 数据总条数
              :param base_url: 请求路径
              :param page_range: 显示页数, 标准网页页码数
              :param get_url : 用户除 p 参数之外提交的其他 get 参数, 用来拼接 url
              """
              try:
                  current_page = int(current_page)
              except Exception as e:
                  current_page = int(1)
              self.current_page = current_page
              self.per_page_num = per_page_num
              # 数据总条数 / 每页页数  如果 余数为 0 商就就是页数, 如果非零  页数就是 商 + 1
              quotient, remainder = divmod(all_count, per_page_num)
              if remainder != 0:
                  self.all_page = quotient + 1   # all_page 总页数
              else:
                  self.all_page = quotient
              self.base_url = base_url
              self.page_range = page_range
              self.get_url = get_url
              # 限制当前页的 范围
              if current_page < 1:
                  self.current_page = 1
              elif current_page >self.all_page:
                  self.current_page = self.all_page
      
          def start(self):
              return (self.current_page - 1) * self.per_page_num
      
          def end(self):
              return self.current_page * self.per_page_num
      
          def page_str(self):
              '''在 HTML 页面中显示页码信息'''
              page_list = []
      
              # 首页
              home_page = '<li><a href="%s?p=1%s">首页</a></li>'%(self.base_url, self.get_url)
              page_list.append(home_page)
              # 限制 上一页
              if self.current_page <=1:
                  previous = '<li><a href="">上一页</a></li>'
              else:
                  previous = '<li><a href="%s?p=%s%s">上一页</a></li>' %(self.base_url,self.current_page-1, self.get_url)
              page_list.append(previous)
      
      
              # 整个 大 if 的作用 : 使用 start 与 end 类限制页码的个数
              if self.all_page <= self.page_range:
                  # 此 if 的 作用 : 当页码总数 <= 最大页码显示的个数, 时触发
                  start = 1
                  end = self.all_page
              else:
                  if self.current_page > int(self.page_range/2):
                      if self.current_page >= self.all_page-int(self.page_range/2):
                          # 此 if 循环 : 当前页码 >= 最大页码-标准页码/2 时触发, 不然就会出现没有数据的假页码,
                          # 比如最大页码, 113 此时就会出现 114 , 114 就是假页码
                          start = self.all_page - self.page_range + 1 # 如果不加 1 页码数, 开始的页码就会是 标准页码多一个
                              # 这个时候开始生成为就应该是, 最大页码 - 标准页码 + 1 = 这时页面上的页码才是 标准页码个数
                          end = self.all_page + 1 # 最后一只能是 最大页码
                      else:
                          start = self.current_page - int(self.page_range/2)
                          end = self.current_page + int(self.page_range/2)+1
                  else:
                      # 处理 首页的几页页
                      start = 1 # 说明页码的开头必须是 1
                      end = self.page_range +1 #
      
              # for i in range(1, self.all_page+1):
              for i in range(start, end):
                  # for 的作用: 循环生成页码, 而页码的个数是在 self.page_range 中指定
                  # start 与 end 是为了限制页码的个数
      
                  # if 判断的 用途 , 为了实现, 只有在中间的 页码 才有  class="active" 属性
                  if self.current_page == i:
                      temp = '<li class="active"><a href="%s?p=%s%s">%s</a></li>'%(self.base_url, i, self.get_url, i)
                  else:
                      temp = '<li><a href="%s?p=%s%s">%s</a></li>' % (self.base_url, i, self.get_url, i)
                  page_list.append(temp)
      
              # 限制 下一页
              if self.current_page >= self.all_page:
                  next_page = '<li><a href="">下一页</a></li>'
              else:
                  next_page = '<li><a href="%s?p=%s%s">下一页</a></li>' %(self.base_url,self.current_page+1, self.get_url)
              # 添加进列表
              page_list.append(next_page)
      
      
              # 尾页
              home_page = '<li><a href="%s?p=%s%s">尾页</a></li>'%(self.base_url, self.all_page, self.get_url)
              page_list.append(home_page)
              return ''.join(page_list)
      
    2. 调用的视图函数 (视图文件)
      def data_count(request):
          all_count = models.District.objects.count()
          from .page_info import PageInfo
          base_url = request.path_info
          page_info = PageInfo(request.GET.get('p'), 10, all_count, base_url)
          user_list = models.District.objects.filter(id__range=[page_info.start(),page_info.end()])
          return render(request, 'users2.html',{'user_list':user_list})
      
    3. template 文件
      <body>
          <div style=" 800px; margin: 0 auto">
              <h1>用户列表</h1>
              <table class="table table-hover table-bordered">
                  <tr>
                      <th>ID</th>
                      <th>用户名</th>
                      <th>密码</th>
                      <th>邮箱</th>
                  </tr>
                  {% for i in user_list %}
                  <tr>
                      <td>{{ i.id }}</td>
                      <td>{{ i.name }}</td>
                      <td>{{ i.password }}</td>
                      <td>{{ i.email }}</td>
                  </tr>
                  {% endfor %}
              </table>
              <div>
                  <nav aria-label="...">
                      <ul class="pagination">
                          {# 分页页码 #}
                          {{ page_info.page_str|safe }}
                      </ul>
                  </nav>
              </div>
          </div>
      </body>
      
  • 相关阅读:
    MySQL mysqlbinlog 读取mysql-bin文件出错
    MySQL slow_log表不能修改成innodb引擎
    Linux 进程一直占用单核CPU分析
    Linux 磁盘告警分析
    Linux 查看文件被那个进程写数据
    springboot项目访问jsp404
    springboot项目启动控制台显示端口被占用解决方法
    js密码强弱正则校验、邮箱校验
    Java Base64加密解密例子
    mysql按日期做曲线图统计,如果当天没有数据则日期不全、补全日期
  • 原文地址:https://www.cnblogs.com/dream4567/p/8799717.html
Copyright © 2011-2022 走看看