Django實現分頁顯示效果
更新時間:2019年10月31日 15:57:17 作者:LinBigCat
這篇文章主要為大家詳細介紹了Django實現分頁顯示效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
Django中提供了一個類Paginator專門用來管理和處理分頁數據,所以我們在使用之前先導入好相應的類,,另外這里我們也導入了待會會用到的處理異常的兩個類 EmptyPage和PageNotAnInteger:
from django.core.paginator import Paginator, EmptyPage, PageNotAnInteger
接著編寫好視圖函數test:
def test(request):
course_list=CourseVideo.objects.all()
#生成pagintor對象,定義每頁顯示10條記錄
paginator=Paginator(course_list,10)
#獲取當前的頁碼數,默認為1
page=request.GET.get("page",1)
#把當前的頁碼數轉換為整數類型
currentPage=int(page)
try:
video_list=paginator.page(page)#獲取當前頁碼的記錄
except PageNotAnInteger:
video_list=paginator.page(1)#如果用戶輸入的頁碼不是整數時,顯示第1頁的內容
except EmptyPage:
video_list=paginator.page(paginator.num_pages)#如果用戶輸入的頁碼不是整數時,顯示第1頁的內容
return render(request, "test.html", locals())
接下來我們完成前端頁面的邏輯,這里定義的文件為test.html:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>這里的標題</title>
</head>
<body>
<div class="manageContent">
{#數據顯示div--start#}
{% for video in video_list%}
<div id="{{ video.vidoeContentId }}" class="content9">
<div class="videomsg">
<img src="/static/images/favicon.ico" alt="" />
<span >{{ video.name }}</span>
</div>
<span class="courseTime" >{{ video.number }}</span>
<span class="sourse" >{{ video.source }}</span>
<span class="status" >{{ video.status }}</span>
<div class="operate">
<span style="cursor:pointer;" onclick="ShowUpDiv('upfileDiv','fade1','{{ video.id }}','{{ video.name }}')">上傳</span>
<span style="cursor:pointer;" onclick="ShowEditDiv('editDiv','editfade','{{ video.name }}','{{ video.number }}','{{ video.source }}','{{ video.status }}','{{ video.id }}')" >修改</span>
<span style="cursor:pointer;" onclick="Showdetail('{{ video.id }}')" >詳情</span>
</div>
<div id="{{ video.id }}" style="display: none ;overflow:scroll;overflow-x:hidden">
</div>
</div>
{% endfor %}
{#數據顯示div--end#}
{#顯示分頁導航欄--start#}
<div class="kkk">
<ul class="pagination" id="pager" >
{#上一頁按鈕開始#}
{# 如果當前頁有上一頁#}
{% if video_list.has_previous %}
{# 當前頁的上一頁按鈕正常使用#}
<li class="previous"><a href="/backstage/test/?page={{ video_list.previous_page_number }}" >上一頁</a></li>
{% else %}
{# 當前頁的不存在上一頁時,上一頁的按鈕不可用#}
<li class="previous disabled"><a href="#" >上一頁</a></li>
{% endif %}
{#上一頁按鈕結束#}
{# 頁碼開始#}
{% for num in paginator.page_range %}
{% if num == currentPage %}
<li class="liactive"><a class="selected" href="/backstage/test/?page={{ num }}" >{{ num }}</a></li>
{% else %}
<li class="itemli"><a href="/backstage/test/?page={{ num }}" >{{ num }}</a></li>
{% endif %}
{% endfor %}
{#頁碼結束#}
{# 下一頁按鈕開始#}
{% if video_list.has_next %}
<li class="next"><a href="/backstage/test/?page={{ video_list.next_page_number }}" >下一頁</a></li>
{% else %}
<li class="next disabled"><a href="#" >下一頁</a></li>
{% endif %}
{# 下一頁按鈕結束#}
</ul>
</div>
{#顯示分頁導航欄--end#}
</div>
</body>
</html>
至此,分頁顯示的邏輯完成,更多關于Paginator的語法實例如下:
from django.core.paginator import Paginator objects = ['john','paul','george','ringo','lucy','meiry','checy','wind','flow','rain']<br> p = Paginator(objects,3) # 3條數據為一頁,實例化分頁對象 print p.count # 10 對象總共10個元素 print p.num_pages # 4 對象可分4頁 print p.page_range # xrange(1, 5) 對象頁的可迭代范圍 page1 = p.page(1) # 取對象的第一分頁對象 print page1.object_list # 第一分頁對象的元素列表['john', 'paul', 'george'] print page1.number # 第一分頁對象的當前頁值 1 page2 = p.page(2) # 取對象的第二分頁對象 print page2.object_list # 第二分頁對象的元素列表 ['ringo', 'lucy', 'meiry'] print page2.number # 第二分頁對象的當前頁碼值 2 print page1.has_previous() # 第一分頁對象是否有前一頁 False print page1.has_other_pages() # 第一分頁對象是否有其它頁 True print page2.has_previous() # 第二分頁對象是否有前一頁 True print page2.has_next() # 第二分頁對象是否有下一頁 True print page2.next_page_number() # 第二分頁對象下一頁碼的值 3 print page2.previous_page_number() # 第二分頁對象的上一頁碼值 1 print page2.start_index() # 第二分頁對象的元素開始索引 4 print page2.end_index() # 第2分頁對象的元素結束索引 6
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
舉例講解Python程序與系統(tǒng)shell交互的方式
這篇文章主要介紹了Python程序與系統(tǒng)shell交互的方式,舉了一個非常簡單的hello world的例子,需要的朋友可以參考下2015-04-04
python創(chuàng)建只讀屬性對象的方法(ReadOnlyObject)
有時需要創(chuàng)建一個帶只讀屬性的對象,大家可以參考下如下的方法進行創(chuàng)建,稍加改造,可以得到很特殊的效果2013-02-02
windows下安裝python paramiko模塊的代碼
windows下安裝python paramiko模塊,有需要的朋友可以參考下2013-02-02

