2 django系列之django分页与templatetags

preface

当页面出现的条目多的时候,我们就需要使用分页功能了。Django作为一个知名的web框架,自然也提供了分页功能,下面说说它。

Python-shell 练练手

在python下入手

先创建一个操作对象
>>> hehe = ['ljf','richer','wang',1,2,3]
>>> hehe
['ljf', 'richer', 'wang', 1, 2, 3]
表示每页两份,表示把hehe这个列表每一页2份数据
>>> p = Paginator(hehe,2)       #表示每页两份,表示把hehe这个列表每一页2份数据
>>> p
<django.core.paginator.Paginator object at 0x0000000000B75630>
统计多少个值
>>> p.count           #统计多少个值
6
统计多少页
>>> p.num_pages         #统计多少页
3
查看页数
>>> p.page_range     #查看页数
range(1, 4)
取第一页的内容
>>> p1=p.page(1)       #取第一页的内容
>>> p1
>>> p1.object_list
['ljf', 'richer']
获取第二页
>>> p2=p.page(2)                 
>>> p2
<Page 2 of 3>
显示当前页内容
>>> p2.object_list
['wang', 1]
判断是否有一下页
>>> p2.has_next() #判断是否有一下页
True
判断是否有上一页
>>> p1.has_previous()            # 判断是否有上一页
False  
判断是否还有其他页
>>> p1.has_other_pages()          # 判断是否还有其他页
True

在html中使用分页功能

在html中,我们需要使用django 的templatetags功能来实现动态显示当前页的前后3页,避免页数过大导致页码太长。这个功能可以参考官网的例子(https://docs.djangoproject.com/en/1.10/howto/custom-template-tags/)。

我们首先查看项目目录,自己写的tag在app下面新建一个目录templatetags,必须是这个名字:

[root@salt devops]# tree BatchM
BatchM
├── Batch
│   ├── templatetags
│   │   ├── custom_tag.py   # 这个就是自己定义的tag.
│   │   ├── __init__.py
custom_tag.py的内容

from django import templatefrom django.utils.html import format_html
register = template.Library()   # 注册到tempate库里面@register.filter   # filter只能对一个参数传入有效,调用到时候这样用  {{ xx.line  | ljf_power}} 
def ljf_lower(val):    #这个仅仅是测试练习写的代码,可以忽略。return val.lower()@register.simple_tag()     # simple_tag能够对传入多个参数有效
def guess_page(current_page,loop_num):''':param current_page:  当前页:param loop_num:     页数范围:return:'''offset = abs(current_page - loop_num)if offset < 3:   # 表示取当前页的前后三页if current_page == loop_num :page_element = '''       <li class="active"><a href="?page=%s">%s<span class="sr-only">(current)</span></a></li>'''%(loop_num,loop_num)                 # 拼html代码else:page_element = '''<li><a href="?page=%s">%s<span class="sr-only">(current)</span></a></li>'''%(loop_num,loop_num)return format_html(page_element)else:return ''                 # 必须写一个return 空字符串,这样就不会在前端页面显示None
我们再看看调用这个tags的html代码
提前引入bootstrap,jquery。
{% load custom_tag %}           # 需要引用刚才创建的tag
''''省略其他代码N行<nav><ul class="pagination">{% if contacts.has_previous %}    <!-- 判断是否有首页  --><li class="disabled"><a href="#">&laquo;</a></li>{% endif %}{% for page_num in contacts.paginator.page_range %}{% guess_page contacts.number  page_num %}    <!--   guess_page 直接写刚才在tag里面定义的方法,  contacts.numer表示时当前页,page_num表示for循环到元素-->{% endfor %}{% if contacts.has_next %}           <!-- 判断是否有下一页 --><li class="disabled"><a href="#">&raquo;</a></li>{% endif %}</ul></nav>
再看views里面的代码:
def apply_update_search(request):''':param request::return:'''if request.method == 'GET':records = models.WorkOrderOfUpdate.objects.filter(username=request.user.get_username()).order_by('OrderId').reverse()  #数据库搜索page = request.GET.get('page')        # 与前端页面的a标签链接保持一致try:contacts = pageinator.page(page)except PageNotAnInteger:      # 如果输入到不是一个数字,发送第一页contacts = pageinator.page(1)except EmptyPage:   # 如果获取到超过来页数范围,那么就返回最后一页。contacts = pageinator.page(pageinator.num_pages)return render(request,'apply_update.html',{'btitle':'搜索操作记录','contacts':contacts})
url配置
url(r"apply_update.html/search",views.apply_update_search,name='post_order_id') 

以上功能完成后,就可以实现这样的功能:

转载于:https://www.cnblogs.com/liaojiafa/p/6231385.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/572859.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

计算传递函数乘法_软件开发教程:计算机科学最重要的32个算法

软件开发的根本在于解决各种业务功能需要&#xff0c;实现数字化和自动化&#xff0c;而算法(Algorithm)是对解决方案的准确而完整的描述&#xff0c;是一系列解决问题的清晰指令。算法代表着用系统的方法描述解决问题的策略机制。在计算机科学领域有32个重要的算法需要研究。简…

Rails下cloud datastore的使用

Rails下cloud datastore的使用 背景 部门有一个项目要用Ruby做 WebAPI&#xff0c;DB使用关系型数据库Cloud Sql和非关系型数据库Cloud Datastore 。 还不了解Ruby On Rails和CloudDatastore的请参考下面的链接。 http://guides.ruby-china.org/ https://thinkit.co.jp/story/2…

hanlp 词频统计_10.HanLP实现k均值--文本聚类

AI人工智能10.HanLP实现k均值--文本聚类10. 文本聚类正所谓物以类聚&#xff0c;人以群分。人们在获取数据时需要整理&#xff0c;将相似的数据归档到一起&#xff0c;自动发现大量样本之间的相似性&#xff0c;这种根据相似性归档的任务称为聚类。10.1 概述聚类聚类(cluster a…

追本溯源 —— 汉语词汇含义的演化

1. 比喻义 枷&#xff1a;旧时一种套在脖子上的刑具&#xff08;想象水浒传里的林冲&#xff0c;还要把手塞进去&#xff09;&#xff1a;&#xff5e;锁&#xff08;旧时的两种刑具&#xff0c;喻束缚&#xff09;。转载于:https://www.cnblogs.com/mtcnn/p/9422411.html

view 冒号作用 组件中属性_如何解析名称中带有冒号的JSON?安卓/ Java...

例如&#xff1a;{“ primary&#xff1a;title”&#xff1a;“小红帽”}由于主要名称和标题之间存在冒号,因此我在Java(Android)中的解析器总是卡住.我可以轻松解析其他任何内容,我只需要帮助.public class MainActivity extends Activity {/** Called when the activity is …

【工具与解决方案】从做项目中积累学习

【Java-Swing】 1.http://java-mans.iteye.com/blog/1650786 JAVA&#xff0d;SWT如何在Jtable单元格中加入复选框Jcheckbox,Jbutton,JcomboBox 2.环境搭建 http://blog.csdn.net/ghuil/article/details/40652645 http://www.cnblogs.com/yaowukonga/archive/2013/02/28/29…

目标检测排行榜_3D领域重大突破!大华股份人工智能取得KITTI Object 3D车辆检测排行榜第一名...

[导读]近日&#xff0c;大华股份基于深度学习技术研发的3D目标检测技术&#xff0c;刷新了The KITTI Vision Benchmark Suite中3D车辆类目检测任务(3D Object Detection Evaluation)排行榜&#xff0c;取得了3D车辆类目检测第一名&#xff0c;这标志着大华股份的人工智能技术在…

MYSQL-5.5二进制包安装

groupadd mysql 添加用户组 useradd mysql -s /sbin/nologin -g mysql -M 添加用户 mv mysql-5.5.54-linux2.6-x86_64.tar.gz /home/ye/software/ 下载软件到软件包 cd /home/ye/software/ tar -xf mysql-5.5.54-linux2.6-x86_64.tar.gz #解压mysql软件 cd mysql-5.5.54-lin…

mysql aes encrypt_mysql加密函数aes_encrypt()和aes_decrypt()使用教程

aes_encrypt()和aes_decrypt()在mysql中是进行加密了&#xff0c;我们今天一起来和各位看看关于mysql中aes_encrypt()和aes_decrypt()函数的使用例子&#xff0e;如果你需要对mysql某些字段进行加解密的话,使用mysql的加解密函数可能比程序中处理更方便.mysql-encrypt-funcs.pn…

为什么选择mysql_为什么选择MySQL数据库即MySQL优势介绍

{"moduleinfo":{"card_count":[{"count_phone":1,"count":1}],"search_count":[{"count_phone":4,"count":4}]},"card":[{"des":"阿里云数据库专家保驾护航&#xff0c;为用户…

窗口尺寸,文档高,元素宽高的获取方式

一.元素宽高&#xff1a; window.onload function() { var oDiv document.getElementById(div1); /* width height style.width : 样式宽 clientWidth : 可视区宽 offsetWidth : 占位宽 */ alert( oDiv.style.width ); /…

Mariadb使用总结

一、pt-quert-digest使用1、安装perl程序12yum -y install perl-Time-HiResyum -y install perl-DBI二、登录授权123456789service mysqld stop/usr/bin/mysqld_safe --skip-grant-tables &use mysql;update user set passwordpassword(yournewpasswordhere) where userroo…

python执行到input后执行下一程序_Python基础知识储备,如何开关一个while循环

一、什么是循环循环语句就是在某种条件下&#xff0c;一遍一遍重复的执行某个动作。如&#xff1a;从1加到100&#xff0c;重复执行加法的动作&#xff0c;就需要用到循环。二、循环的三要素虽然循环是反复的执行某个动作&#xff0c;但是循环也会停止的&#xff0c;没有停止的…

Intellij idea添加单元测试工具

1.idea 版本是14.0.0 &#xff0c;默认带有Junit&#xff0c;但是不能自动生成单元测试&#xff0c;需要下载JunitGererator2.0插件 2.Settings -Plugins&#xff0c;下载 JunitGenerator V2.0插件 &#xff0c;我的是已经下载好的。下载后提示需要重启 3.下载后 点击需要测试的…

string.empty , , null 以及性能的比较

一&#xff1a;这种结论&#xff0c;个人觉得仍然存疑 http://www.cnblogs.com/wangshuai901/archive/2012/05/06/2485657.html 1.null null 关键字是表示不引用任何对象的空引用的文字值。null 是引用类型变量的默认值。那么也只有引用型的变量可以为NULL&#xff0c;如果 int…

mysql查询当前库的实例名_oracle查询数据库名、实例名等

oracle中&#xff1a;1、查询数据库名&#xff1a;select name,dbid from v$database;或者show parameter db_name;2、查询实例名&#xff1a;select instance_name from v$instance;或者show parameter instance_name;3、查询数据库域名&#xff1a;select value from v$param…

JPA 系列教程21-JPA2.0-@MapKeyColumn

MapKeyColumn 用JoinColumn注解和MapKeyColumn处理一对多关系 ddl语句 CREATE TABLE t_employee (id bigint(20) NOT NULL AUTO_INCREMENT,name varchar(255) DEFAULT NULL,PRIMARY KEY (id) ) ENGINEInnoDB AUTO_INCREMENT2 DEFAULT CHARSETutf8;CREATE TABLE t_employee_map…

错误:在keystone中无法找到默认角色user_Kubernetes RBAC角色权限控制

摘选:https://i4t.com/4448.html在Kubernetes中所有的API对象都保存在ETCD里&#xff0c;可是&#xff0c;对这些API对象的操作&#xff0c;却一定是通过访问kube-apiserver实现的。我们需要APIServer来帮助我们授权工作&#xff0c;而在Kubernetes项目中&#xff0c;负责完成授…

JAVAWEB项目如何实现验证码

验证码基础 一.什么是验证码及它的作用 &#xff1a;验证码为全自动区分计算机和人类的图灵测试的缩写,是一种区分用户是计算机的公共全自动程序,这个问题可以由计算机生成并评判,但是必须只有人类才能解答.可以防止恶意破解密码、刷票、论坛灌水、有效防止某个黑客对某一个特定…

在线判题系统(oj)效果分析图_在线代码编写平台开发分享

计算机专业的大学生应该都了解acm比赛&#xff0c;这种通过使用oj(online judge)系统在线编程刷题&#xff0c;实时反馈学习排名的方式能很大程度激发学生的学习热情。oj学习排名界面oj个人学习记录界面只是oj平台一般都只适用后端语言&#xff0c;如java&#xff0c;c#, c,C&a…