url文件

from django.contrib import admin
from django.conf.urls import url
from app01 import views urlpatterns = [
url(r'^user_list', views.user_list)
]

对views文件

def user_list(request):
pagesizenumber = request.COOKIES.get('pagesizenumber', 10) #获取COOKIE传过来的key('pagesizenumber'), 默认为10
current_number = request.GET.get('p', 1) #获得前端a的?p = 的值,此为当前页码数
one_page_number = 11 #每页显示的页码数
pagefi = pagenation.Page(List, pagesizenumber, current_number, one_page_number) #生成类
(show_page, list_page) = pagefi.page_str() #返回两个参数
return render(request, 'user_list.html', {'show_page' : show_page, 'list_page': list_page})

对于上述的pagenation.Page 中为Page.py 文件

from django.utils.safestring import mark_safe
class Page: def __init__(self, List, pagesizenumber, current_number, one_page_number = 11):
# List 输入传入的数据, pagesizenumber 每页显示的数据量,current_number 当前页码, one_page_number:每页页码数,默认11
self.pagesizenumber = pagesizenumber
self.current_number = current_number
self.one_page_number = one_page_number
self.List = List @property
def page_number(self):
self.one_math_number = int(self.pagesizenumber)
page_number, v = divmod(len(self.List), self.one_math_number) # page_number 总页码数, 计算所需要的总页码数
return page_number
@property
def show_page(self):
self.current_number = int(self.current_number) #当前页码数
self.one_math_number = int(self.pagesizenumber)
page_number, v = divmod(len(self.List), self.one_math_number) #计算得需要的总页码数
if v > 0:
page_number += 1 # 如果大于1, 页码数+1
show_page = self.List[(self.current_number - 1) * self.one_math_number:self.current_number * self.one_math_number] # 显示在页面的数
return show_page def page_str(self):
list_page = []
self.current_number = int(self.current_number)
self.one_math_number = int(self.pagesizenumber)
self.one_page_number = int(self.one_page_number) if self.page_number < self.one_page_number: # 总页码数小于单页页码数
start_page = 1
end_page = int(self.page_number) + 1
else: # 总页码数大于单页码数
if self.current_number <= int((self.one_page_number + 1) / 2): # 当前页码 小于 单页页码数中间
start_page = 1
end_page = int(self.one_page_number) + 1
print(start_page)
print(end_page)
elif self.page_number - int((self.one_page_number - 1) / 2) > self.current_number > int(
(self.one_page_number + 1) / 2): # 当前页码数 大于 单页页码数中间 小于 总页码数-单页页码中间 #开始发生变化
start_page = int(self.current_number - ((self.one_page_number) - 1) / 2)
end_page = int(self.current_number + ((self.one_page_number) + 1) / 2)
else:
start_page = self.page_number - self.one_page_number # 当前页码数大于总页码数-单页页码中间
end_page = self.page_number + 1
# 上一页按钮
if self.current_number == 1:
x = ("<a class='paging active' href='#'>上一页</a>")
else:
x = ("<a class='paging active' href='/user_list/?p=%s'>上一页</a>" % (self.current_number - 1,))
list_page.append(x)
# 添加a标签
for i in range(start_page, end_page):
if i == self.current_number:
x = ("<a class='paging active' href='/user_list/?p=%s'>%s</a>" % (i, i))
else:
x = ("<a class='paging' href='/user_list/?p=%s'>%s</a>" % (i, i)) list_page.append(x)
# 下一页按钮
if self.current_number == self.page_number:
x = ("<a class='paging active' href='#'>下一页</a>")
else:
x = ("<a class='paging active' href='/user_list/?p=%s'>下一页</a>" % (self.current_number + 1,))
list_page.append(x) x = '''
<input type="text"><a onclick = 'jumpTo(this, "/user_list/?p=")';>Go</a>
<script>
function jumpTo(ths, base){
var val = ths.previousSibling.value;
location.href = base + val; }
</script>
'''
# ths.previousSibling.value 找出在其上面的input的value值
# location.href = base + val 跳转
# x = '''
# <input type='text' ><a onclick='jumpTo(this, "/user_list/?p=")';>Go</a>
# <script>
# function jumpTo(ths,base){
# var val = ths.previousSibling.value;
# location.href = base + val;
# }
# </script>
# '''
list_page.append(x) list_page = ''.join(list_page)
print(list_page)
list_page = mark_safe(list_page)
return self.show_page, list_page

对于user_list.html文件

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<style>
.pagination .paging{
padding: 5px;
margin: 5px;
background-color: aqua;
color: white;
}
.pagination .paging.active{
background-color: red;
color: white; }
</style>
</head>
<body>
<ul>
{% for i in show_page %}
<li>{{ i }}</li>
{% endfor %}
</ul>
{# {% for i in list_page %}#}
{# <a class='paging' href="/user_list/?p={{ i }}">{{ i }}</a>#}
{# {% endfor %}#} <div class = pagination>
{{ list_page }}
</div>
{# onchange 检测改变#}
<select id = 'i1' onchange="changePageSize(this)">
<option value="">10</option>
<option value="">30</option>
<option value="">50</option>
<option value="">100</option>
</select>
<script src = '/static/jquery-3.3.1.js'></script>
<script src="/static/jquery.cookie.js"></script>
<script>
{# 文件一进来就执行该操作, 获得pagesizenumber值,改变values, 初始值为10#}
$(function () {
var v = $.cookie('pagesizenumber');
if (v){$('#i1').val(v);}
else{$('#i1').val(10)}
});
function changePageSize(ths) {
var v = $(ths).val();
$.cookie('pagesizenumber', v, {path:'/user_list/'});
location.reload();
{# 刷新实现跳转#} } </script> </body>
</html>

django网页的分页功能,大家如果有疑问请留言的更多相关文章

  1. Django实现简单分页功能

    使用django的第三方模块django-pure-pagination 安装模块: pip install django-pure-pagination 将'pure_pagination'添加到s ...

  2. Django自定制分页功能

    URL: """django_paginner URL Configuration The `urlpatterns` list routes URLs to views ...

  3. django网页图片验证码功能

    在一个正常的登录系统中,验证码是非常重要的,用于识别人机,毕竟我们都知道,这个世界中存在着万恶的爬虫,验证码有很多种方式,有图片的,有邮件的,有短信的,有拼图的,不管什么样的验证码,目的都是验证访问用 ...

  4. 利用rest-framework实现django应用的分页功能

    自定义分页的类,继承 PageNumberPagination class StandardResultsSetPagination(PageNumberPagination): page_size ...

  5. Django 之 Paginator 分页功能

    Django Paginator Django 分页官方文档  https://docs.djangoproject.com/en/1.10/topics/pagination/ 此分页方法没有限制显 ...

  6. 【原】django实现列表分页功能

    在view.py里添加分页查询方法: from django.http import JsonResponse from django.views.decorators.http import req ...

  7. Django,ajax实现表格增删查改,Django内置分页功能。

    1.工程目录 2.urls.py """Django_ajax URL Configuration The `urlpatterns` list routes URLs ...

  8. django内置分页功能扩展

    实现自定制页码数类型class myPaginator(Paginator): def __init__(self,curr_page,per_page_num,*args,**kwargs): se ...

  9. django中如何实现分页功能

    1.在html页面中导入js文件和css文件 <link rel="stylesheet" href="../../../static/css/jquery.pag ...

随机推荐

  1. javascript中typeof用法

    JS中的变量是松散类型(即弱类型)的,可以用来保存任何类型的数据. typeof 可以用来检测给定变量的数据类型,可能的返回值: 1. 'undefined' --- 这个值未定义: 2. 'bool ...

  2. Luogu 1452 Beauty Contest

    Luogu 1452 Beauty Contest 求平面最远点对,先求出凸包,再找凸包的直径. 使用旋转卡壳,直径一定出现在对踵点对间.比较不同点到同一直线距离可以用叉积算三角形面积来比较. 实现时 ...

  3. 在 Windows 安装期间将 MBR 磁盘转换为 GPT 磁盘

    以 UEFI 启动的 Windows 磁盘必须是 GPT 格式.本文将介绍如何在安装 Windows 期间将磁盘从 MBR 转换成 GPT. 特别注意:操作不慎可能丢失所有数据,如果你懂得安装系统的一 ...

  4. C#/.NET 中的契约

    将文档放到代码里面,文档才会及时地更新! 微软从 .NET Framework 4.0 开始,增加了 System.Diagnostics.Contracts 命名空间,用来把契约文档融入代码.然而后 ...

  5. 将 UWP 的有效像素(Effective Pixels)引入 WPF

    在很久很久以前,WPF 诞生之初,有一个神奇的单位,它的名字叫做——设备无关单位(DIP,Device Independent Unit).微软给它描绘了一片美好的愿景——在任何显示器上显示的尺寸是相 ...

  6. C++ set容器

    STL中的set容器的一点总结:(元素唯一,且排序) 1.关于set (头文件:<set>) C++ STL 之所以得到广泛的赞誉,也被很多人使用,不只是提供了像vector, strin ...

  7. Machine Schedule(二分图匹配之最小覆盖点,匈牙利算法)

    个人心得:二分图啥的一点都不知道,上网借鉴了下,请参考http://blog.csdn.net/thundermrbird/article/details/52231639 加上自己的了解,二分图就是 ...

  8. LeetCode 755. Pour Water

    原题链接在这里:https://leetcode.com/problems/pour-water/description/ 题目: We are given an elevation map, hei ...

  9. drill 表&&视图使用

    1.  table    create table table_name as select * from storage_name.dbname.tablename   2. view   crea ...

  10. 最短路径问题的Dijkstra算法

      问题 最短路径问题的Dijkstra算法 是由荷兰计算机科学家艾兹赫尔·戴克斯特拉提出.迪科斯彻算法使用了广度优先搜索解决非负权有向图的单源最短路径问题,算法终于得到一个最短路径树>    ...