Django實(shí)現(xiàn)簡單分頁功能的方法詳解
本文實(shí)例講述了Django實(shí)現(xiàn)簡單分頁功能的方法。分享給大家供大家參考,具體如下:
使用django的第三方模塊django-pure-pagination
安裝模塊:
pip install django-pure-pagination
將'pure_pagination'添加到settings.py文件中
INSTALLED_APPS = ( ... 'pure_pagination', )
在view.py文件中
from django.shortcuts import render
rom .models import mymodel
from pure_pagination import Paginator, EmptyPage, PageNotAnInteger
def NewsList(request):
all_news = mymodel.objects.all().order_by('-add_time')
# 分頁功能
try:
page = request.GET.get('page', 1)
except PageNotAnInteger:
page = 1
p = Paginator(all_news, 3, request=request)
news = p.page(page)
return render(request, 'rdxw.html', {'all_news': news})
在template.py文件中調(diào)用view傳遞的參數(shù)'all_news'需要加上'.object_list'
{% extends 'base.html' %}
{% block content %}
<ul>
{% for new in all_news.object_list %}
<li>{{new.content}}</li>
{% endblock %}
</ul>
實(shí)現(xiàn)翻頁的部分:
<div class="pageturn">
<ul class="pagelist">
{% if all_news.has_previous %}
<li class="long"><a href="?{{ all_news.previous_page_number.querystring }}" rel="external nofollow" >上一頁</a></li>
{% endif %}
{% for page in all_news.pages %}
{% if page %}
{% ifequal page all_news.number %}
<li class="active"><a href="?{{ page.querystring }}" rel="external nofollow" rel="external nofollow" >{{ page }}</a></li>
{% else %}
<li><a href="?{{ page.querystring }}" rel="external nofollow" rel="external nofollow" class="page">{{ page }}</a></li>
{% endifequal %}
{% else %}
<li class="none"><a href="">...</a></li>
{% endif %}
{% endfor %}
{% if all_news.has_next %}
<li class="long"><a href="?{{ all_news.next_page_number.querystring }}" rel="external nofollow" >下一頁</a></li>
{% endif %}
</ul>
</div>
樣式較文檔提供的簡化了很多,方便使用。
.pageturn .pagelist {
display: table-cell;
vertical-align: middle;
overflow: hidden;
}
.pageturn li {
width: 30px;
height: 30px;
line-height: 30px;
margin-left: 10px;
float: left;
text-align: center;
}
.pageturn li:first-child {
margin-left: 0;
}
.pageturn li:hover a, .pageturn .active a {
background: #717171;
color: #fff;
border-color: #eaeaea;
}
.pageturn a {
border: 1px solid #eaeaea;
display: block;
height: 28px;
color: #6c6c6c;
}
.pageturn .long {
width: 100px;
}
.pageturn .none a {
border: 0;
}
.pageright {
float: right;
width: auto;
display: inline;
clear: none;
margin-top: 10px;
}
更多關(guān)于Python相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python加密解密算法與技巧總結(jié)》、《Python編碼操作技巧總結(jié)》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》及《Python入門與進(jìn)階經(jīng)典教程》
希望本文所述對大家Python程序設(shè)計(jì)有所幫助。
- django實(shí)現(xiàn)分頁的方法
- Python Django實(shí)現(xiàn)layui風(fēng)格+django分頁功能的例子
- Django分頁查詢并返回jsons數(shù)據(jù)(中文亂碼解決方法)
- Django實(shí)現(xiàn)快速分頁的方法實(shí)例
- Django實(shí)現(xiàn)分頁功能
- Django自定義分頁與bootstrap分頁結(jié)合
- Django原生sql也能使用Paginator分頁的示例代碼
- Django實(shí)現(xiàn)網(wǎng)頁分頁功能
- Django框架實(shí)現(xiàn)分頁顯示內(nèi)容的方法詳解
- Django實(shí)現(xiàn)簡單的分頁功能
相關(guān)文章
PyTorch一小時(shí)掌握之遷移學(xué)習(xí)篇
這篇文章主要介紹了PyTorch一小時(shí)掌握之遷移學(xué)習(xí)篇,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-09-09
Python?Cloudinary實(shí)現(xiàn)圖像和視頻上傳詳解
這篇文章主要介紹了Python?Cloudinary實(shí)現(xiàn)圖像和視頻上傳功能,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧2022-11-11

