温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Django中怎么利用Paginator实现分页

发布时间:2021-08-09 13:46:26 阅读:156 作者:Leah 栏目:大数据
GO开发者专用服务器限时活动,0元免费领,库存有限,领完即止! 点击查看>>

Django中怎么利用Paginator实现分页,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

一、通过模型创建Subject

Django models

from django.db import models class Subject(models.Model):         """学科""”         no = models.AutoField(primary_key=True, verbose_name="编号")         name = models.CharField(max_length=31, verbose_name="名称")         intro = models.CharField(max_length=511, verbose_name="介绍")         def __str__(self):                 return self.name             class Meta:                 db_table = 'tb_subject’                 verbose_name_plural = "学科"

二、通过view模块,要呈现到前端的数据

Django view 的配置

from django.shortcuts import renderfrom django.core.paginator import Paginator, InvalidPage, EmptyPage, PageNotAnIntegerfrom vote.models import Subjectdef show_subject(request):    """查询学科"""    #查询Subject 表的所有数据    subjects = Subject.objects.all().order_by("no”)    #使用Paginator模块对数据分页,一页5条数据    paginator = Paginator(subjects, 5)    #使用request.GET.get()函数获取uri中的page参数的数值    page = request.GET.get('page')    try:        #通过获取上面的page参数,查询此page是否为整数并且是否可用        subject_obj = paginator.page(page)    except PageNotAnInteger:        subject_obj = paginator.page(1)    except (EmptyPage, InvalidPage):        subject_obj = paginator.page(paginator.num_pages)    return render(request, "vote/subject.html", {'subject_list': subject_obj})

三、将view中的数据渲染到前端模版上

前端分页代码块

<div class="pull-right" pagination”>                        <!—  分页功能前端的方向箭头代码-->                        {% if subject_list.has_previous %}                        <li class="enabled">                            <a href="?page={{ subject_list.previous_page_number }}" aria-label="Previous">                                <span aria-hidden="true">&laquo;</span>                            </a>                        </li>                        {% endif %}                        <!—  分页功能显示页码的中间部分代码-->                        {% for page_num in subject_list.paginator.page_range %}                            {% if page_num == subject_list.number %}                                <li class="active">                                    <a href="#">                                        {{ page_num }}                                        <span class="sr-only">(current)</span>                                    </a>                                </li>                            {% else %}                                <li>                                    <a href="?page={{ page_num }}">{{ page_num }}                                        <span class="sr-only">(current)</span>                                    </a>                                </li>                            {% endif %}                        {% endfor %}                        <!—  分页功能末端的方向箭头代码-->                        {% if  subject_list.has_next %}                        <li class="enabled">                            <a href="?page={{ subject_list.next_page_number }}" aria-label="last">                                <span aria-hidden="true">&raquo;</span>                            </a>                        </li>                        {% endif %}                    </ul>                </nav></div>

四、最终显示结果

Django中怎么利用Paginator实现分页

关于Django中怎么利用Paginator实现分页问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注亿速云行业资讯频道了解更多相关知识。

亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

原文链接:https://my.oschina.net/u/4007037/blog/4387861

AI

开发者交流群×