django自带的分页虽然挺好,但是就想自己弄个通用的

自己写了个分页的类,用的是python,   其他语言改下语法就能用了.

#定义好类.
class pagemanage:
def __init__(self,page_each,data_count,cur_page,pageint,url):
''' :param page_each: 每次显示多少页
:param data_count: 数据总条数
:param cur_page: 当前页面数
:param pageint: 每一页显示的数据条数
:param url:渲染地址
'''
self.page_each=page_each
self.cur_page = cur_page
self.pageint = pageint
self.get_url=url
self.data_count=data_count @property#获取总共的页数
def get_countpage(self):
a, v = divmod(self.data_count, self.pageint)
self.page_count = a # page_count总的页数 if v != 0:
self.page_count = a + 1
if self.cur_page >self.page_count:
self.cur_page=self.page_count
return self.page_count # 获取每次页面显示的区间
@property
def get_interval_page(self):
page_count = self.get_countpage
if self.page_each>page_count:
start=1
end=page_count
return [start, end]
elif self.cur_page<self.page_each/2:
start = 1
end=self.page_each
return [start, end]
elif self.cur_page>page_count-self.page_each/2:
start=page_count-self.page_each+1
end=page_count
return [start, end]
else:
if self.page_each%2==0:
start=self.cur_page-self.page_each/2+1
end=self.cur_page+self.page_each/2 else:
start = self.cur_page - self.page_each / 2 #python3请改成 '//'
end = self.cur_page + self.page_each / 2 #python3请改成 '//'
return [start,end] def get_pageint(self): start = (self.cur_page - 1) * self.pageint end = (self.cur_page) * self.pageint page_start_end=(start,end) return page_start_end #将分页渲染成html标签 字符串 def getpager(self): page_list = [] if self.cur_page == 1: page_list.append("<a href=''>上一页</a>") else: page_list.append("<a href='/%s/?p=%s'>上一页</a>" % (self.get_url,self.cur_page - 1)) for i in range(self.get_interval_page[0], self.get_interval_page[1]+1): if i == self.cur_page: page_list.append("<a style='background-color: black ' href='/%s/?p=%s'>%s</a>" % (self.get_url,i, i)) continue page_list.append("<a href='/%s/?p=%s'>%s</a>" % (self.get_url,i, i)) if self.cur_page == self.get_countpage: page_list.append("<a href=''>下一页</a>") else: page_list.append("<a href='/%s/?p=%s'>下一页</a>" % (self.get_url,self.cur_page + 1)) pager = "".join(page_list) return pager

使用---------views

def xxxx(req):
cur_page = int(req.GET.get("p", 1)) # 默认为1,获取当前页码
data_count = models.Student.objects.all().count()#数据的总数
p = pagemanage(2,data_count,cur_page, 10, "mmm/getstudentdata")#使用自己写好的分页类
pager = p.getpager()#获取最后返回的字符串,就是包含标签的字符串
pageint = p.get_pageint()#获取到本次的显示页的起始数据和结束数据 data = models.Student.objects.all()[pageint[0]:pageint[1]]#获取显示的数据 return render(req, 'studentm.html', {'data': data, 'page_set': pager})

html

  <table>

 {% for i in data %}//循环显示每条内容
<tr>
<td>{{ i.id }}</td>
<td>{{ i.name }}</td>
<td>{{ i.cls.name }}</td>
<td><a class="modify" href="/mmm/modify?nid={{ i.id }}">编辑</a>|<a href="javascript:void(0)">删除</a></td>
</tr>
{% endfor %}
</table> <div class="pagemode">//显示分页
{{ page_set|safe }}
</div>

简单实用的分页类-python的更多相关文章

  1. PHP简单漂亮的分页类

    本文介绍一款原生的PHP分页类,分页样式有点类似bootstrap. <?php /* * ********************************************* * @类名 ...

  2. 一个简单的php分页类代码(转载)

    入门级php分页类 原文地址:http://www.xfcodes.com/php/fenye/3608.htm 时间:2015-12-16 20:52:00来源:网络 php分页类. 复制代码代码如 ...

  3. THinkPHP简单漂亮的分页类 DownLoad

    PHP include_once("config.php"); require_once('page.class.php'); //分页类 $showrow = 10; //一页显 ...

  4. 简单实用的日志类CLog (Python版)

    #coding: utf-8 import time ''' /***************************************************************** Fu ...

  5. 一个简单的CI分页类

    [php] view plaincopy <span style="font-size:16px;">/** * * 关于 页码有效性的判断需要加在 控制器中判断,即当 ...

  6. php简单实用的调试工具类

    <?php /* * 调试类 */ class Common_Debug { //打开错误报告 public static function showError($debug = true) { ...

  7. 简单实用的原生PHP分页类

    一款简单实用的原生PHP分页类,分页按钮样式简洁美观,页码多的时候显示“...”,也是挺多网站用的效果 核心分页代码 include_once("config.php"); req ...

  8. C#反射实现 C# 反射 判断类的延伸类型 使用代码生成工具Database2Sharp快速生成工作流模块控制器和视图代码 C# ADO.NET的SqlDataReader对象,判断是否包含指定字段 页面中添加锚点的几种方式 .net 简单实用Log4net(多个日志配置文件) C# 常用小点

    C#反射实现   一.反射概念: 1.概念: 反射,通俗的讲就是我们在只知道一个对象的内部而不了解内部结构的情况下,通过反射这个技术可以使我们明确这个对象的内部实现. 在.NET中,反射是重要的机制, ...

  9. 简单实用的php分页函数代码

    一个简单实用的php分页函数,分页导航中可以默认为空,在函数内部再设置本页URL. 代码: <?php /** * 分页 * @category 功能 * @param $totle:信息总数 ...

随机推荐

  1. JUnit4测试报错:class not found XXX

     初学java框架,最近用eclipse跟着视频坐淘淘商城这个项目,其中使用了JUnit4做单元测试.当运行测试代码时,项目报错:class not found xxx. 借助了其他大神的博客,论坛等 ...

  2. Floodlight1.2+Mininet的安装及使用

    直接转载的大神的,亲测Ubuntu16.04版本没问题 https://www.sdnlab.com/19189.html

  3. CSS样式补充第二天

    #p1{/*        border-width: 1px;*/        /*边框实线*/        /*border-style: solid;*/        /*边框虚线*/   ...

  4. java 实现自定义事件

    import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; i ...

  5. 创建一个dynamics 365 CRM online plugin (二) - fields检查

    Golden Rules 1. Platform only passes Entity attributes to Plugin that has change of data. 2. If the ...

  6. 计算apk包的安装之后占用空间以及运行时占用内存

    1.统计结果如下 计算apk安装占用空间大小方式 为了方式apk包运行时出现缓存数据等对空间计算造成影响.应该先进行安装,然后分别计算空间变化 所有apk包安装完毕后再运行 开启两个cmd窗口 第一个 ...

  7. 东芝 B-EV4 打印机 串口打印命令

    最近在做项目时候使用了东芝的B-EV4打印机,在打印Excel时候由于字体太小,导致打印非常模糊.只能通过串口名称发送打印指令进行打印.在做项目的时候查了很多关于B-EV4打印机的资料,和打印命令.资 ...

  8. c#读sql server数据添加到MySQL数据库

    using System;using System.Collections.Generic;using System.Text;using Console = System.Console;using ...

  9. centos 7中监控mysql 数据库脚本(监控端口)

    centos 7中监控mysql 数据库脚本(监控端口) 监控mysql数据库的方法如下: 1.监控端口 netstat -nltp |grep 3306 2.监控进程 ps -ef |grep 33 ...

  10. Linux下安装jdk8步骤详述

    作为Java开发人员,在Linux下安装一些开发工具是必备技能,本文以安装jdk为例,详细记录了每一步的操作命令,以供参考. 0.下载jdk8 登录网址:http://www.oracle.com/t ...