django中分页的实现

  1. 安装django插件
pip install dj_pagination
  1. 在settings.py中配置
INSTALLED_APPS = [
    'dj_pagination'
]
MIDDLEWARE = [
  ....
'dj_pagination.middleware.PaginationMiddleware',
]

  1. 加载分页标签
  {% load pagination_tags %}


{% autopaginate gs_list 2 %}
# 在需要分页的遍历式子上加上 自动分页以及每页的个数
{% for gs in gs_list %}

最后在需要展示分页的地方输入
  {% paginate %}
  1. 美化分页标签
    把E:\python\Scripts\myblog\Lib\site-packages\dj_pagination\templates\pagination文件下的pagination.html更改为以下内容即可
{% if is_paginated %}
{% load i18n %}
<nav aria-label="Page navigation example">
<ul class="pagination">
  {% block previouslink %}
  {% if page_obj.has_previous %}
  {% if disable_link_for_first_page and page_obj.previous_page_number == 1 %}
  <li class="page-item"><a href="{{ request.path }}{% if getvars %}?{{ getvars|slice:"1:" }}{% endif %}" class="prev page-link">{{ previous_link_decorator|safe }}{% trans "" %}</a></li>
  {% else %}
  <li class="page-item"><a href="?page{{ page_suffix }}={{ page_obj.previous_page_number }}{{ getvars }}" class="prev page-link">{{ previous_link_decorator|safe }}{% trans "" %}</a></li>
  {% endif %}
  {% else %}
  {% if display_disabled_previous_link %}
  <li class="page-item"><span class="disabled prev page-link">{{ previous_link_decorator|safe }}{% trans "previous" %}</span></li>
  {% endif %}
  {% endif %}
  {% endblock previouslink %}
  {% block pagelinks %}
  {% if display_page_links %}
  {% for page in pages %}
  {% if page %}
  {% ifequal page page_obj.number %}
  <li class="page-item active"><a class="current page page-link ">{{ page }}<span class="sr-only">(current)</span></a></li>
  {% else %}
  {% if disable_link_for_first_page and page == 1 %}
  <li class="page-item"><a href="{{ request.path }}{% if getvars %}?{{ getvars|slice:"1:" }}{% endif %}" class="page page-link">{{ page }}</a></li>
  {% else %}
  <li class="page-item"><a href="?page{{ page_suffix }}={{ page }}{{ getvars }}" class="page page-link">{{ page }}</a></li>
  {% endif %}
  {% endifequal %}
  {% else %}
  <li class="page-item">...</li>
  {% endif %}
  {% endfor %}
  {% endif %}
  {% endblock pagelinks %}
  {% block nextlink %}
  {% if page_obj.has_next %}
  <li class="page-item"><a href="?page{{ page_suffix }}={{ page_obj.next_page_number }}{{ getvars }}" class="next page-link">{% trans "" %}{{ next_link_decorator|safe }}</a></li>
  {% else %}
  {% if display_disabled_next_link %}
  <li class="page-item"><span class="disabled next page-link">{% trans "" %}{{ next_link_decorator|safe }}</span></li>
  {% endif %}
  {% endif %}
  {% endblock nextlink %}
</ul>
</nav>
{% endif %}



最后是dj-pagination中setting中的可选事项修改,位置在Lib\site-packages\dj_pagination

在dj-pagination中,没有必需的设置。但是,有一小组可选设置可用于更改分页标记的默认行为。这是一个概述:

PAGINATION_DEFAULT_PAGINATION

如果未指定编号,则在页面上显示的默认项目数。默认为20

PAGINATION_DEFAULT_WINDOW

要显示的当前页面左侧和右侧的项目数(占省略号)。默认为4。#感觉改为2或3的效果会更好一点

PAGINATION_DEFAULT_MARGIN

FIXME:这需要记录在案。

PAGINATION_DEFAULT_ORPHANS

被定义为“最后一页允许的最小项目数,默认为零”。

PAGINATION_INVALID_PAGE_RAISES_404

确定无效页面是否引发Http404或仅设置 invalid_page上下文变量。 True是前者还是False 后者。默认为False

PAGINATION_DISPLAY_PAGE_LINKS

如果设置为False,则不会显示单个页面的链接。默认为True。

PAGINATION_PREVIOUS_LINK_DECORATOR

上一页链接的HTML前缀; 默认值是&lsaquo;&lsaquo;。

PAGINATION_NEXT_LINK_DECORATOR

用于下一页链接的HTML后缀; 默认值是&rsaquo;&rsaquo;。

PAGINATION_DISPLAY_DISABLED_PREVIOUS_LINK

如果设置为False,如果没有上一页,则不会显示上一页链接。默认为False。

PAGINATION_DISPLAY_DISABLED_NEXT_LINK

如果设置为False,如果没有下一页,则不会显示下一页链接。默认为False。

PAGINATION_DISABLE_LINK_FOR_FIRST_PAGE

如果设置为False,则第一页将?page=1显示分页中的链接后缀,否则将被省略。默认为True。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,036评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,046评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,411评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,622评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,661评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,521评论 1 304
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,288评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,200评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,644评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,837评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,953评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,673评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,281评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,889评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,011评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,119评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,901评论 2 355

推荐阅读更多精彩内容

  • Django提供了一些类来帮助你管理分页的数据 -- 也就是说,数据被分在不同页面中,并带有“上一页/下一页”标签...
    yunpiao阅读 1,155评论 0 0
  • 世界上最遥远的距离,不是我在你身边,你却不知道我爱你。而是,我就在你身边,你已经不认识我,我还要看着深爱的你全心全...
    林慕言阅读 445评论 0 0
  • 一个人一生中 总要去一次西藏 不为那天高地远的无限风光, 不为神秘圣洁的转山仪式, 也不为仓央嘉措的低吟浅唱, 就...
    闽江学院阅读 362评论 0 2
  • 家里的小妞最近总是不太平,上周彪到40度这周又呕吐。在为人父母这个道场里摸爬滚打,也总算对于幼儿期的这种事件泰然处...
    cheryl_217阅读 284评论 2 0