1. 程式人生 > >分頁器

分頁器

判斷 shortcuts 顯示 render 上一頁 pps style install 技術

分頁器

這裏使用的是github上的一個開源包,github上搜索pure_pagination,找到那個star最多的就可以了

安裝

pip install django-pure-pagination

將pure-pagination增加到配置文件INSTALLED_APPS下邊

INSTALLED_APPS = (
    ...
    pure_pagination,
)

後端代碼

from django.shortcuts import render
from pure_pagination import Paginator, EmptyPage, PageNotAnInteger


def index(request): try: page = request.GET.get(page, 1) except PageNotAnInteger: page = 1 p = Paginator(all_orgs,5,request=request) #實例化一個分頁器對象,需要三個參數,第一個是一個可叠代對象,第二個是分多少頁 orgs = p.page(page) return render(request,org-list.html,{ "all_orgs
":orgs, })

前端邏輯

<div class="pageturn">
     <ul class="pagelist">
         {% if all_orgs.has_previous %}
             <li class="long"><a href="?{{ all_orgs.previous_page_number.querystring }}">上一頁</a></li>//判斷有沒有上一頁,有就顯示,沒有就不顯示

         {% endif %}
         {
% for page in all_orgs.pages %} {% if page %} {% ifequal page all_orgs.number %} <li class="active"><a href="?{{ page.querystring }}">{{ page }}</a></li> {% else %} <li><a href="?{{ page.querystring }}" class="page">{{ page }}</a></li> {% endifequal %} {% else %} <li class="none"><a href="" class="page">...</a></li> {% endif %} {% endfor %} {% if all_orgs.has_next %} <li class="long"><a href="?{{ all_orgs.next_page_number.querystring }}">下一頁</a></li> {% endif %} </ul> </div>

ok了,分頁器大概就是這麽實現的了,可以當做一個小工具移植到很多的項目裏面

技術分享圖片

分頁器