Django實(shí)現(xiàn)分頁(yè)顯示效果
Django中提供了一個(gè)類Paginator專門(mén)用來(lái)管理和處理分頁(yè)數(shù)據(jù),所以我們?cè)谑褂弥跋葘?dǎo)入好相應(yīng)的類,,另外這里我們也導(dǎo)入了待會(huì)會(huì)用到的處理異常的兩個(gè)類 EmptyPage和PageNotAnInteger:
from django.core.paginator import Paginator, EmptyPage, PageNotAnInteger
接著編寫(xiě)好視圖函數(shù)test:
def test(request): course_list=CourseVideo.objects.all() #生成pagintor對(duì)象,定義每頁(yè)顯示10條記錄 paginator=Paginator(course_list,10) #獲取當(dāng)前的頁(yè)碼數(shù),默認(rèn)為1 page=request.GET.get("page",1) #把當(dāng)前的頁(yè)碼數(shù)轉(zhuǎn)換為整數(shù)類型 currentPage=int(page) try: video_list=paginator.page(page)#獲取當(dāng)前頁(yè)碼的記錄 except PageNotAnInteger: video_list=paginator.page(1)#如果用戶輸入的頁(yè)碼不是整數(shù)時(shí),顯示第1頁(yè)的內(nèi)容 except EmptyPage: video_list=paginator.page(paginator.num_pages)#如果用戶輸入的頁(yè)碼不是整數(shù)時(shí),顯示第1頁(yè)的內(nèi)容 return render(request, "test.html", locals())
接下來(lái)我們完成前端頁(yè)面的邏輯,這里定義的文件為test.html:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>這里的標(biāo)題</title> </head> <body> <div class="manageContent"> {#數(shù)據(jù)顯示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 %} {#數(shù)據(jù)顯示div--end#} {#顯示分頁(yè)導(dǎo)航欄--start#} <div class="kkk"> <ul class="pagination" id="pager" > {#上一頁(yè)按鈕開(kāi)始#} {# 如果當(dāng)前頁(yè)有上一頁(yè)#} {% if video_list.has_previous %} {# 當(dāng)前頁(yè)的上一頁(yè)按鈕正常使用#} <li class="previous"><a href="/backstage/test/?page={{ video_list.previous_page_number }}" >上一頁(yè)</a></li> {% else %} {# 當(dāng)前頁(yè)的不存在上一頁(yè)時(shí),上一頁(yè)的按鈕不可用#} <li class="previous disabled"><a href="#" >上一頁(yè)</a></li> {% endif %} {#上一頁(yè)按鈕結(jié)束#} {# 頁(yè)碼開(kāi)始#} {% 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 %} {#頁(yè)碼結(jié)束#} {# 下一頁(yè)按鈕開(kāi)始#} {% if video_list.has_next %} <li class="next"><a href="/backstage/test/?page={{ video_list.next_page_number }}" >下一頁(yè)</a></li> {% else %} <li class="next disabled"><a href="#" >下一頁(yè)</a></li> {% endif %} {# 下一頁(yè)按鈕結(jié)束#} </ul> </div> {#顯示分頁(yè)導(dǎo)航欄--end#} </div> </body> </html>
至此,分頁(yè)顯示的邏輯完成,更多關(guān)于Paginator的語(yǔ)法實(shí)例如下:
from django.core.paginator import Paginator objects = ['john','paul','george','ringo','lucy','meiry','checy','wind','flow','rain']<br> p = Paginator(objects,3) # 3條數(shù)據(jù)為一頁(yè),實(shí)例化分頁(yè)對(duì)象 print p.count # 10 對(duì)象總共10個(gè)元素 print p.num_pages # 4 對(duì)象可分4頁(yè) print p.page_range # xrange(1, 5) 對(duì)象頁(yè)的可迭代范圍 page1 = p.page(1) # 取對(duì)象的第一分頁(yè)對(duì)象 print page1.object_list # 第一分頁(yè)對(duì)象的元素列表['john', 'paul', 'george'] print page1.number # 第一分頁(yè)對(duì)象的當(dāng)前頁(yè)值 1 page2 = p.page(2) # 取對(duì)象的第二分頁(yè)對(duì)象 print page2.object_list # 第二分頁(yè)對(duì)象的元素列表 ['ringo', 'lucy', 'meiry'] print page2.number # 第二分頁(yè)對(duì)象的當(dāng)前頁(yè)碼值 2 print page1.has_previous() # 第一分頁(yè)對(duì)象是否有前一頁(yè) False print page1.has_other_pages() # 第一分頁(yè)對(duì)象是否有其它頁(yè) True print page2.has_previous() # 第二分頁(yè)對(duì)象是否有前一頁(yè) True print page2.has_next() # 第二分頁(yè)對(duì)象是否有下一頁(yè) True print page2.next_page_number() # 第二分頁(yè)對(duì)象下一頁(yè)碼的值 3 print page2.previous_page_number() # 第二分頁(yè)對(duì)象的上一頁(yè)碼值 1 print page2.start_index() # 第二分頁(yè)對(duì)象的元素開(kāi)始索引 4 print page2.end_index() # 第2分頁(yè)對(duì)象的元素結(jié)束索引 6
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Django Paginator分頁(yè)器的使用示例
- Django drf分頁(yè)器的使用詳解
- Django分頁(yè)器的用法詳解
- Django分頁(yè)器的用法你都了解嗎
- Django實(shí)現(xiàn)簡(jiǎn)單的分頁(yè)功能
- 如何在django中實(shí)現(xiàn)分頁(yè)功能
- Django 自定義分頁(yè)器的實(shí)現(xiàn)代碼
- 通過(guò) Django Pagination 實(shí)現(xiàn)簡(jiǎn)單分頁(yè)功能
- Django 簡(jiǎn)單實(shí)現(xiàn)分頁(yè)與搜索功能的示例代碼
- Django前端BootCSS實(shí)現(xiàn)分頁(yè)的方法
相關(guān)文章
Python Pandas工具繪制數(shù)據(jù)圖使用教程
Pandas是基于NumPy 的一種工具,該工具是為解決數(shù)據(jù)分析任務(wù)而創(chuàng)建的。Pandas還可以繪制多重?cái)?shù)據(jù)圖表,本文將為大家介紹如何通過(guò)Pandas繪制圖表,感興趣的可以了解一下2021-12-12Python實(shí)現(xiàn)簡(jiǎn)單石頭剪刀布游戲
這篇文章主要為大家詳細(xì)介紹了Python實(shí)現(xiàn)簡(jiǎn)單的石頭剪刀布的游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-01-01python 數(shù)據(jù)類型強(qiáng)制轉(zhuǎn)換的總結(jié)
這篇文章主要介紹了python 數(shù)據(jù)類型強(qiáng)制轉(zhuǎn)換的使用總結(jié),幫助大家更好的理解和使用python,感興趣的朋友可以了解下2021-01-01python3.7+anaconda 安裝opencv和dlib的問(wèn)題及解決方法
這篇文章主要介紹了python3.7+anaconda 安裝opencv和dlib的問(wèn)題及解決方法,本文圖文并茂給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-08-08python爬蟲(chóng)之驗(yàn)證碼篇3-滑動(dòng)驗(yàn)證碼識(shí)別技術(shù)
本篇涉及到的驗(yàn)證碼為滑動(dòng)驗(yàn)證碼,不同于極驗(yàn)證,本驗(yàn)證碼難度略低,需要的將滑塊拖動(dòng)到矩形區(qū)域右側(cè)即可完成。對(duì)python爬蟲(chóng)滑動(dòng)驗(yàn)證碼識(shí)別技術(shù)感興趣的朋友跟隨小編一起看看吧2019-04-04