测试版本

代码:

# 测试分页users=[{'name':'alex{}'.format(i),'pwd':'aaa{}'.format(i)}for i in range(1,302)]

def user_list(request):        # 获取当前页码值 并处理异常 输入字母也显示第一页  默认为第一页    try:        current_page=int(request.GET.get('page',1))        # 如果小于o 显示页面为1        if current_page<=0:            current_page=1    except Exception as e:        current_page=1#     最多显示页码数    max_show=11    half_show=max_show//2

#每页显示数量    per_num=10#         总数量    all_count=len(users)#     总页数    total_num,more=divmod(all_count,per_num)#     判断是否有剩余的    if more:        total_num +=1

    #总页面数小于最大显示数: 显示总页码数    if total_num<max_show:        page_start= 1        page_end=total_num    #总页面数大于最大显示数: 显示总页码数    else:        # 当前页面数 小于一半        if current_page<=half_show:            page_start=1            page_end=max_show        # 当前页面数加一半 大于总页面数        elif current_page +half_show >=total_num:            page_end = total_num            page_start=total_num -max_show +1        else:            page_start=current_page - half_show            page_end=current_page +half_show        # 存放li标签的列表    html_list=[]    #     写首页 直接跳转    first_li='<li><a href="/crm/user_list/?page=1">首页</a></li>'    html_list.append(first_li)    # 添加点击到第一页 不能点    if current_page ==1:        prev_li='<li class="disabled"><a><<</a></li>'    #  可以点击上一页    else:        prev_li='<li><a href="/crm/user_list/?page={0}"><<</a></li>'.format(current_page - 1)    html_list.append(prev_li)

    # 循环 分页 在后端添加样式再传到前端    for num in range(page_start,page_end+1):        # 给当前页面加样式        if current_page==num:            li_html='<li class="active"><a href="/crm/user_list/?page={0}">{0}</a></li>'.format(num)        #     否则不加        else:            li_html = '<li ><a href="/crm/user_list/?page={0}">{0}</a></li>'.format(num)        html_list.append(li_html)

    # 添加点击到最后一页 不能点    if current_page==total_num:        next_li='<li class="disabled"><a>>></a></li>'        #  可以点击下一页    else:        next_li = '<li><a href="/crm/user_list/?page={0}">>></a></li>'.format(current_page + 1)    html_list.append(next_li)        #     写尾页 直接跳转    last_li = '<li><a href="/crm/user_list/?page={}">尾页</a></li>'.format(total_num)    html_list.append(last_li)    #在前端显示全部界面\

    html_str=mark_safe(''.join(html_list))

    # 获取切片起始值  current_page为页数,因为是切片取第一页要从零开始 要减一    start=(current_page-1)*per_num    # 获取切片终止值    end=current_page *per_num

    return render(request,'user_list.html',                  {'data':users[start:end],                   # 'total_num':range(page_start,page_end+1)                   'html_str': html_str                   }                  )html代码:(里面有模板与继成)
{% extends 'board/base.html' %}

{% block conten %}

    <table class="table table-bordered">        <thead>        <tr>            <th>序号</th>            <th>用户名</th>            <th>密码</th>        </tr>        </thead>        <tbody>        {% for user in data %}            <tr>                <td>{{ forloop.counter }}</td>                <td>{{ user.name }}</td>                <td>{{ user.pwd }}</td>            </tr>        {% endfor %}

        </tbody>    </table>

    <nav aria-label="Page navigation">        <ul class="pagination">{#            {% for num in total_num %}#}{#                <li><a href="/crm/user_list/?page={{ num }}">{{ num }}</a></li>{% endfor %}#}

            {#            {% for num in total_num %}#}            {#                <li><a href="/user_list/?page={{ num }}">{{ num }}</a></li>#}            {#            {% endfor %}#}            {#            {{ html_str|safe }}#}            {{ html_str }}        </ul>    </nav>

{% endblock %}

自己定义类 现在项目同级建一个 utils的文件夹  里面创建pagination.pypagination.py代码:
# 分页器from django.utils.safestring import mark_safe

class Pagination:    def  __init__(self,request,all_count,per_num=10, max_show=11):        # 基本的URL        self.base_url=request.path_info        try:            self.current_page=int(request.GET.get('page',1))            # 如果小于o 显示页面为1            if self.current_page<=0:                self.current_page=1        except Exception as e:            self.current_page=1    #     最多显示页码数        self.max_show=max_show        half_show=max_show//2

    #每页显示数量        self.per_num=per_num    #         总数量        self.all_count=all_count    #     总页数

        self.total_num,more=divmod(all_count,per_num)    #     判断是否有剩余的        if more:            self.total_num +=1

        #总页面数小于最大显示数: 显示总页码数        if self.total_num<max_show:            self.page_start=1            self.page_end=self.total_num        #总页面数大于最大显示数: 显示总页码数        else:            # 当前页面数 小于一半            if self.current_page<=half_show:                self.page_start=1                self.page_end=max_show            # 当前页面数加一半 大于总页面数            elif self.current_page +half_show >=self.total_num:                self.page_end = self.total_num                self.page_start=self.total_num -max_show +1            else:                self.page_start=self.current_page - half_show                self.page_end=self.current_page +half_show

    @property    def start(self):        # 获取切片起始值  current_page为页数,因为是切片取第一页要从零开始 要减一

        return (self.current_page - 1) * self.per_num    @property    def end(self):        # 获取切片终止值

        return self.current_page * self.per_num    @property    def show_li(self):        # 存放li标签的列表        html_list = []        #     写首页 直接跳转        first_li = '<li><a href="{}?page=1">首页</a></li>'.format(self.base_url)        html_list.append(first_li)        # 添加点击到第一页 不能点        if self.current_page == 1:            prev_li = '<li class="disabled"><a><<</a></li>'        #  可以点击上一页        else:            prev_li = '<li><a href="{1}?page={0}"><<</a></li>'.format(self.current_page - 1,self.base_url)        html_list.append(prev_li)

        # 循环 分页 在后端添加样式再传到前端        for num in range(self.page_start, self.page_end + 1):            # 给当前页面加样式            if self.current_page == num:                li_html = '<li class="active"><a href="{1}?page={0}">{0}</a></li>'.format(num,self.base_url)            #     否则不加            else:                li_html = '<li ><a href="{1}?page={0}">{0}</a></li>'.format(num,self.base_url)            html_list.append(li_html)

        # 添加点击到最后一页 不能点        if self.current_page == self.total_num:            next_li = '<li class="disabled"><a>>></a></li>'            #  可以点击下一页        else:            next_li = '<li><a href="{1}?page={0}">>></a></li>'.format(self.current_page + 1,self.base_url)        html_list.append(next_li)        #     写尾页 直接跳转        last_li = '<li><a href="{1}?page={0}">尾页</a></li>'.format(self.total_num,self.base_url)        html_list.append(last_li)        # 在前端显示全部界面\

        return mark_safe(''.join(html_list))
views.py代码:
from utils.pagination import Pagination
# 客户展示页面def page(request):    ret_all=models.Customer.objects.all()    # 接收数据的次数    pagee = Pagination(request,ret_all.count())    return render(request,'board/page.html',{'ret':ret_all[pagee.start:pagee.end],'pagination':pagee.show_li                })
# 测试分页users=[{'name':'alex{}'.format(i),'pwd':'aaa{}'.format(i)}for i in range(1,302)]
def user_list(request):    page=Pagination(request,len(users))

    return render(request, 'user_list.html',                  {'data': users[page.start:page.end],                   # 'total_num':range(page_start,page_end+1)                   'html_str': page.show_li                   }                  )
html.py代码:
{% extends 'board/base.html' %}

{% block conten %}      <h2 class="sub-header">客户信息 </h2>          <div class="table-responsive">            <table class="table table-striped table-hover table-bordered">              <thead>                <tr>                    <th>序号</th>                  <th>QQ</th>                  <th>QQ昵称</th>                  <th>姓名</th>                  <th>性别</th>                    <th>手机号</th>                    <th>客户来源</th>                    <th>咨询课程</th>                    <th>班级类型</th>                    <th>状态</th>                    <th>最后跟进日期</th>                    <th>预计再次跟进时间</th>                    <th>销售</th>                  <th>已报班级</th>                </tr>              </thead>              <tbody>              {% for i in ret %}               <tr>                  <td>{{ forloop.counter }}</td>                   <th>{{ i.qq }}</th>                  <th>{{ i.qq_name|default:'暂无' }}</th>                  <th>{{ i.name|default:'暂无' }}</th>                  <th>{{ i.get_sex_display }}</th>                    <th>{{ i.phone|default:'暂无' }}</th>                    <th>{{ i.get_source_display }}</th>                   <th>{{ i.course }}</th>                    <th>{{ i.get_class_type_display }}</th>                    <th>{{ i.show_status }}                    </th>                    <th>{{ i.last_consult_date }}</th>                   <th>{{ i.next_date }}</th>                   <th>{{ i.consultant|default:'暂无' }}</th>                  <th>{{ i.show_class }}</th>                </tr>              {% endfor %}

              </tbody>            </table>          <div style="text-align: right">              <nav aria-label="Page navigation">        <ul class="pagination">

            {{ pagination }}        </ul>    </nav>          </div>     </div>{% endblock  %}
 




												

最新文章

  1. Deep learning:五十(Deconvolution Network简单理解)
  2. python运维开发坎坷之路-01
  3. 【java】 获取计算机信息及Java信息
  4. ArcGis(01)——地图切片以及发布底图服务
  5. CSS布局注意(纯属个人总结)
  6. object-c中的BOOL类型
  7. details和summary可以对内容进行折叠
  8. Fragment多重嵌套实现电影,影院展示页
  9. SQL语句-delete语句
  10. 安卓 新版本 获取wifi状态网络是否可用等
  11. echarts--迁徙图特性简介
  12. 【Netty】(5)源码 Bootstrap
  13. 20. Web proxies (网页代理 4个)
  14. 学习笔记之English
  15. spring+struts+hibernate整合
  16. 第一篇 入门必备 (Android学习笔记)
  17. PAT乙级 解题目录
  18. MVVM Light 笔记
  19. CentOS6安装NodeJS(非编译)
  20. hive如何使用中文查询条件

热门文章

  1. 玩转TypeScript(3)--类型转换
  2. sql,用 ISNULL(), NVL(), IFNULL() and COALESCE() 函数替换空值
  3. ARM_Instruction_Set_Encoding_hacking(ARM指令集编码格式解读)
  4. GPA
  5. [LeetCode&amp;Python] Problem 693. Binary Number with Alternating Bits
  6. HDU 1003:Max Sum(DP,连续子段和)
  7. 51Nod:1995 三子棋
  8. leetcode:Pascal&#39;s Triangle【Python版】
  9. socat 广播以及多播
  10. 【Android界面实现】AppWidght全面学习之电量监控小部件的实现具体解释