1、创建pager.py文件,针对翻页进行函数书写

class PageInfo(object):
# current_page 当前页数
# all_count 所有行
# per_page 每页的行数
# show_page 控制只显示11个按钮
def __init__(self, current_page, all_count, per_page, base_url, show_page=5):
try:
self.current_page = int(current_page)
except Exception as e:
self.current_page = 1
self.per_page = per_page a, b = divmod(all_count, per_page) if b:
a = a + 1
self.all_pager = a
self.base_url = base_url
self.show_page = show_page
print(a, b,per_page)
def start(self):
return (self.current_page - 1) * self.per_page def end(self):
return self.current_page * self.per_page def pager(self):
page_list = [] # 如果总页数小于11
if self.all_pager < self.show_page:
begin = 1
stop = self.all_pager + 1
# 如果总页数大于11
else:
# 如果当前页小于等于5,一直保持1,11
if self.current_page <= 2:
begin = 1
stop = self.show_page + 1
else:
# 如果当前页大于所有页
if self.current_page + 2 > self.all_pager:
begin = self.all_pager - self.show_page + 1
stop = self.all_pager + 1
else:
begin = self.current_page - 2
stop = self.current_page + 2 + 1 if self.current_page > 1:
prve = "<li><a href='%s/?page=%s'>上一页 </a></li> " % (self.base_url,self.current_page - 1,)
else:
prve = "<li><a href='#'>上一页 </a> </li>"
page_list.append(prve)
fist = "<li><a href='%s/?page=1'>首页 </a></li> " % (self.base_url,)
page_list.append(fist)
for i in range(begin, stop):
if i == self.current_page:
temp = "<li class='active' ><a href='%s/?page=%s'> %s </a></li> " % (self.base_url, i, i)
else:
temp = "<li><a href='%s/?page=%s'> %s </a></li> " % (self.base_url, i, i)
page_list.append(temp)
end = "<li><a href='%s/?page=%s'>尾页 </a> </li>" % (self.base_url,self.all_pager,)
page_list.append(end) if self.current_page < self.all_pager:
nex = "<li><a href='%s/?page=%s'>下一页 </a> </li>" % (self.base_url,self.current_page + 1,)
else:
nex = "<li><a href='#'>下一页 </a></li>"
page_list.append(nex)
return ''.join(page_list)

2、创建函数,调用翻页函数

def userInfo(request):
all_count = models.userInfo.objects.all().count()
print(all_count)
page_info = PageInfo(request.GET.get('page'), all_count, 10, '/userInfo')
user_list = models.userInfo.objects.all()[page_info.start():page_info.end()] return render(request, 'User/userInfo.html', {'user_list': user_list, 'page_info': page_info})

3、前端html展示

{% extends 'layout.html' %}

{% block css %}
<style> </style>
{% endblock %} {% block table %}
<div style="margin: 10px 15px;">
<a class="btn btn-primary" href="/add_userInfo/">添加</a>
</div>
<table class="table table-condensed table-hover table-bordered">
<thead>
<tr>
<th>ID</th>
<th>用户名</th>
<th>姓名</th>
<th>性别</th>
<th>生日</th>
<th>邮箱</th>
<th>操作</th>
</tr>
</thead>
<tbody>
{% for row in user_list %}
<tr>
<td>{{ row.id }}</td>
<td>{{ row.user }}</td>
<td >{{ row.name }}</td>
<td >{{ row.sex }}</td>
<td >{{ row.birthday }}</td>
<td >{{ row.email }}</td>
<td>
<a href="/edit_userInfo/?tid={{ row.id }}">编辑</a>
<a href="/del_userInfo/?tid={{ row.id }}">删除</a>
</td>
</tr>
{% endfor %}
</tbody>
</table> <nav aria-label="Page navigation">
<ul class="pagination">
<li>
<a href="#" aria-label="Previous">
<span aria-hidden="true">«</span>
</a>
</li>
{{ page_info.pager|safe}}
<li>
<a href="#" aria-label="Next">
<span aria-hidden="true">»</span>
</a>
</li>
</ul>
</nav> {% endblock %} {% block js %}
<script src="/static/jquery.min.js"></script>
<script></script> {% endblock %}

4、页面展示

python自定义翻页配置的更多相关文章

  1. IOS开发之--UIScrollView pagingEnabled自定义翻页宽度

    用到UIScrollview的翻页效果时,有时需要显示一部分左右的内容,但是UIScrollView的PagingEnabled只能翻过整页,下面几个简单的设置即可实现 技术点: 1. 创建一个继承U ...

  2. SharePoint 2013 自定义翻页显示列表项

    项目需求:自定义开发一个能分页显示列表项的小部件,允许左右翻页,能根据用户权限来显示管理链接等. 效果如下: 技术要求:使用sharepoint rest API 来获取列表项,这样性能高,能够快速响 ...

  3. FineReport——JS二次开发(自定义翻页按钮)

    FR允许自定义工具栏上面的按钮,并提交JS方法: 对于翻页功能,大概有首页,下一页,上一页,最后一页,以及跳转页等功能. 不得不说的是,在HTML页面自定义的按钮如何获取到报表模板,通过FR提供的JS ...

  4. Activity切换动画(overridePendingTransition)-翻页效果

    Activity的切换动画指的是从一个activity跳转到另外一个activity时的动画.{它包括两个部分:一部分是第一个activity退出时的动画:另外一部分时第二个activity进入时的动 ...

  5. Atitit.pagging  翻页功能解决方案专题 与 目录大纲 v3 r44.docx

    Atitit.pagging  翻页功能解决方案专题 与 目录大纲 v3 r44.docx 1.1. 翻页的重要意义1 1.2. Dep废弃文档   paip.js翻页分页pageing组件.txt1 ...

  6. Web jquery表格组件 JQGrid 的使用 - 5.Pager翻页、搜索、格式化、自定义按钮

    系列索引 Web jquery表格组件 JQGrid 的使用 - 从入门到精通 开篇及索引 Web jquery表格组件 JQGrid 的使用 - 4.JQGrid参数.ColModel API.事件 ...

  7. python(5)字符串处理 (sub,replace,find,index,upper,strip,split,sub翻页

    一,sub和replace的用法 re.sub 函数进行以正则表达式为基础的替换工作 re.sub替换到目标字符串中的a,b或者c,并全部替换 另加上sub翻页操作: re.sub('start=\d ...

  8. 使用Python在自己博客上进行自动翻页

    先上一张代码及代码运行后的输出结果的图! 下面上代码: # coding=utf-8 import os import time from selenium import webdriver #打开火 ...

  9. python爬虫_入门_翻页

    写出来的爬虫,肯定不能只在一个页面爬,只要要爬几个页面,甚至一个网站,这时候就需要用到翻页了 其实翻页很简单,还是这个页面http://bbs.fengniao.com/forum/10384633. ...

随机推荐

  1. Lyndon 相关的炫酷字符串科技

    浅谈从 Lyndon Words 到 Three Squares Lemma By zghtyarecrenj 本文包括:Lyndon Words & Significant Suffixes ...

  2. 三大操作系统对比使用之·Windows10

    时间:2018-10-29 记录:byzqy 本篇是一篇个人对Windows系统使用习惯.技巧和应用推荐的文档,在此记录.分享和后续查询备忘. 打开终端: Win+R,调出"运行" ...

  3. HashMap 为什么线程不安全?

    作者:developer http://cnblogs.com/developer_chan/p/10450908.html 我们都知道HashMap是线程不安全的,在多线程环境中不建议使用,但是其线 ...

  4. Spring中使用@within与@target的一些区别

    目录 背景 模拟项目例子 看看使用@within和@target的区别 @within @target @target 看起来跟合理一点 通知方法中注解参数的值为什么是不一样的 想用@within,但 ...

  5. DPDK 无锁环形队列(Ring)详解

    DPDK 无锁环形队列(Ring) 此篇文章主要用来学习和记录DPDK中无锁环形队列相关内容,结合了官方文档说明和源码中的实现,供大家交流和学习. Author : Toney Email : vip ...

  6. IKEv2协议协商流程: (IKE-SA-INIT 交换)第一包

    文章目录 1. IKEv2 协商总体框架 2. 第一包流程图 3. openswan源码学习 3.1 ikev2parent_outI1() 3.2 ikev2parent_outI1_withsta ...

  7. python模块--datetime

    datatime.date类 构造器 返回值类型 说明 (year, month, day) date   类方法/属性     .max date datetime.date(9999, 12, 3 ...

  8. Apache网页优化

    目录: 一.Apache网页优化概述 二.网页压缩 三.网页缓存 四.隐藏版本信息 五.Apache防盗链 一.Apache网页优化概述 在企业中,部署Apache后只采用默认的配置参数,会引发网站很 ...

  9. java版gRPC实战之四:客户端流

    欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...

  10. RocketMQ详解(二)安装使用详解

    专题目录 RocketMQ详解(一)原理概览 RocketMQ详解(二)安装使用详解 RocketMQ详解(三)启动运行原理 RocketMQ详解(四)核心设计原理 RocketMQ详解(五)总结提高 ...