分頁器
阿新 • • 發佈:2017-12-17
判斷 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, PageNotAnIntegerdef 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了,分頁器大概就是這麽實現的了,可以當做一個小工具移植到很多的項目裏面
分頁器