django 分頁


  有的時候我們會在頁面中展示大量數據,全部都放在一頁可能會降低用戶體驗,Django提供了一個Paginator類來幫助我們管理分頁數據。

起步
介紹分頁器對象的一些屬性和方法

1. 引入該類及相關異常模塊:
from django.core.paginator import Paginator, PageNotAnInteger, EmptyPage
1
Paginator:分頁器對象
PageNotAnInteger:頁碼不是一個整數時引發該異常
EmptyPage:頁碼不在有效范圍時(即數據為空)引發該異常
2. 分頁器對象
分頁器對象的屬性:

object_list, 對象列表即查詢到的數據
per_page, 每一頁展示的內容
orphans=0, 這是一個缺省參數,如果最后一頁的數據小於這個值,會合並到上一頁
allow_empty_first_page=True, 允許首頁為空 ,默認為True
分頁器對象的方法:

方法 描述
page 返回一個Page對象
count 返回對象列表(數據)的長度
num_pages 返回總頁數
page_range 返回頁碼列表
3. Page對象
Page對象是一般用來指定當前頁
Page對象的屬性,

object_list:同樣是指對象列表,不過只包含當前頁的對象
number:當前頁面的頁碼
paginator :指對應的分頁器對象(Paginator )
注意,Paginator對象是由我們進行實例化的,而Page對象在Paginator對象使用page方法時實現

Page對象的方法:

方法 描述
has_next 是否有下一頁
has_previous 是否有上一頁
has_other_pages 是否有上一頁或下一頁
next_page_number 返回下一頁的頁碼
previous_page_number 返回上一頁的頁碼
start_index 返回當前頁起始的對象序號
end_index 返回當前頁結束的對象序號
應用
  介紹完Paginator對象,已經基本可以親自動手實現一個分頁器對象了,但暫時我們不需要那樣做。接下來,來應用該分頁器對象,我已經封裝好了一個函數來使用它。

 1 def split_page(object_list, request, per_page=8):
 2     paginator = Paginator(object_list, per_page)
 3     # 取出當前需要展示的頁碼, 默認為1
 4     page_num = request.GET.get('page', default='1')
 5     # 根據頁碼從分頁器中取出對應頁的數據
 6     try:
 7         page = paginator.page(page_num)
 8     except PageNotAnInteger as e:
 9         # 不是整數返回第一頁數據
10         page = paginator.page('1')
11         page_num = 1
12     except EmptyPage as e:
13         # 當參數頁碼大於或小於頁碼范圍時,會觸發該異常
14         print('EmptyPage:{}'.format(e))
15         if int(page_num) > paginator.num_pages:
16             # 大於 獲取最后一頁數據返回
17             page = paginator.page(paginator.num_pages)
18         else:
19             # 小於 獲取第一頁
20             page = paginator.page(1)
21 
22     # 這部分是為了再有大量數據時,仍然保證所顯示的頁碼數量不超過10,
23     page_num = int(page_num)
24     if page_num < 6:
25         if paginator.num_pages <= 10:
26             dis_range = range(1, paginator.num_pages + 1)
27         else:
28             dis_range = range(1, 11)
29     elif (page_num >= 6) and (page_num <= paginator.num_pages - 5):
30         dis_range = range(page_num - 5, page_num + 5)
31     else:
32         dis_range = range(paginator.num_pages - 9, paginator.num_pages + 1)
33 
34     data = {'page': page, 'paginator': paginator, 'dis_range ': dis_range }
35     return data
View Code

 

 1 <div class="container">
 2     <nav aria-label="Page navigation">
 3       <ul class="pagination">
 4 
 5         <!--上一頁-->
 6         <li class="{% if not page.has_previous %}disabled{% endif %}">
 7           {% if page.has_previous %}
 8             <a href="{% url 'index' %}?page={{ page.previous_page_number }}" aria-label="Previous">
 9           {% endif %}
10             <span aria-hidden="true">&laquo;</span>
11           </a>
12         </li>
13 
14         <!--頁碼-->
15         <!--這里展示頁碼使用傳遞過來的dis_range -->
16         {% for num in dis_range %}
17         <li class="{% if num == page.number %}active{% else %}{% endif %}" >
18           <a href="{% url 'index' %}?page={{ num }}">{{ num }}</a>
19         </li>
20         {% endfor %}
21 
22         <!--下一頁-->  
23         <li class="{% if not page.has_next %}disabled{% endif %}">
24           {% if page.has_next %}
25             <a href="{% url 'index' %}?page={{ page.next_page_number }}" aria-label="Next">
26           {% endif %}
27             <span aria-hidden="true">&raquo;</span>
28           </a>
29         </li>
30 
31       </ul>
32     </nav>
33   </div>
View Code

  

使用了bootstrap中的基本分頁,展示效果如下圖所示:

對應模板代碼:

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM