Django 之 分页功能

HTML代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <link rel="stylesheet" href="/static/bootstrap-3.3.7/dist/css/bootstrap.css">
    <link rel="stylesheet" href="/templates/bootstrap-3.3.7/dist/css/bootstrap-theme.css">
    <script src="/static/jquery3.js"></script>
    <script src="/static/bootstrap-3.3.7/dist/js/bootstrap.js"></script>
</head>
<body>
<h1>图书列表</h1>

<table border="1" class="table table-bordered table-hover">
    <thead>
    <tr>
        <th>ID</th>
        <th>名字</th>
        <th>出版社</th>
        <th>价格</th>
    </tr>
    </thead>
    <tbody>
    {% for book in book_list %}
        <tr>
            <td>{{ book.id }}</td>
            <td>{{ book.title }}</td>
            <td>
                {{ book.publisher.name }}
            </td>
            <td>{{ book.price }}</td>
        </tr>
    {% endfor %}
    </tbody>
</table>
{#重点位置#}
<nav aria-label="Page navigation">
    <ul class="pagination">
        <li>
            <a href="/ormtest/book/?page=1" aria-label="Previous">
                <span aria-hidden="true">首页</span>
            </a>
        </li>
                {{ page_html|safe }}
        <li>
            <a href="/ormtest/book/?page={{ total_page }}" aria-label="Next">
                <span aria-hidden="true">尾页</span>
            </a>
        </li>
    </ul>
</nav>

</body>
</html>

Python 代码

def book_list(request):
    # 每一页显示数量
    per_page = 7

    # 总数据
    total_count = models.Book.objects.all().count()

    # 总共需要多少页显示数据
    total_page, m = divmod(total_count, per_page)
    if m:
        total_page += 1

    # 从URL中取参数,当没有page时,page_num为1,当page_num大于总页数时,赋于最后一页,当page为字符时,异常出错时,为1值
    try:
        page_num = request.GET.get("page")
        page_num = int(page_num)
        if page_num > total_page:
            page_num = total_page
        elif page_num < 1:
            page_num =1
    except Exception as e:
        page_num = 1

    #定义两个变量,截取数据
    data_start = (page_num-1)*per_page
    data_end = page_num*per_page

    #页面上总共展示多少页面
    max_page =11
    if total_page < max_page:
        max_page = total_page

    half_max_page = max_page//2    #结果为5,即左右各5页

    # 页面上展示的面码从那儿结束
    page_end = page_num + half_max_page

    #页面上展示的页码从那儿开始
    page_start = page_num - half_max_page

    #如果当前面减一半比1还小
    if page_start <= 1:
        page_start = 1
        page_end = max_page

    #如果当前页大于总页数
    if page_end >= total_page:
        page_end = total_page
        page_start = total_page-max_page+1

    #在后台拼接分页的html
    html_str_list = []
    for i in range(page_start, page_end+1):
        #为当前加一个active样式
        if i == page_num:
            tmp = ‘<li class=active><a href="/ormtest/book/?page={0}">{0}</a></li>‘.format(i)
        else:
            tmp = ‘<li><a href="/ormtest/book/?page={0}">{0}</a></li>‘.format(i)
        html_str_list.append(tmp)

    #将所有li的html文件拼接连接成一块
    page_html = "".join(html_str_list)
    #print(page_html)

    all_book = models.Book.objects.all()[data_start:data_end]
    return render(request,"book.html",{"book_list":all_book,"page_html":page_html,"total_page":total_page})

展示效果

原文地址:https://blog.51cto.com/12965094/2395798

时间: 2024-11-24 17:02:18

Django 之 分页功能的相关文章

django实现分页功能

在个人博客或者网站上,我们发表文章经常会对博客进行分页,下面代码用django实现: django有它自带的分页功能:Paginator 不过我们用在它基础上开发的另一个包:django-pure-pagination 先了解一下这个包特性: 1.使用与django.core相同的API,因此与现有代码完全兼容. 2.它考虑了现有的GET参数,具有动态查询字符串创建. 3.用html呈现分页功能,开箱即用(方便) 4.使呈现更高级的分页模板更加容易. 使用: 一.安装 在虚拟环境中通过pip安装

django 实现分页功能

分页效果: 视图代码: 1 # -*- coding: utf-8 -*- 2 from django.shortcuts import render,get_object_or_404 3 from django.core.paginator import Paginator,PageNotAnInteger,EmptyPage 4 5 from .models import Article 6 7 # Create your views here. 8 9 def index(request

django分页功能,templatetags的应用

django 将不会将得到的html代码自动转化 from django.utils.html import format_html html =''' <a href='http://www.china.cn'>中国</a>''' format_html(html) django分页 分页功能基本操作 from django.core.import Paginator li=[11,12,13,22,24,25] p=Paginator(li,3) #将li传入,每页显示3条 p

django高级应用(分页功能)

django高级应用(分页功能) 1.原生分页应用 前端html代码 1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset="UTF-8"> 5 <title>Title</title> 6 </head> 7 <body> 8 <ul> 9 {% for item in posts.obj

{oldboy-django][2深入django]分页功能

1 django自带分页 1.1 分页模板 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <link rel="stylesheet" href="/static/plugins/bootstrap-3.3.7-dist/css/boots

django中orm分页功能(内置分页)

分批获取数据的方法 数据库方法 models.Uinfo.objects.all()[10:20] django自带的方法 创建一个新的url urlpatterns = [ url(r'^index.html/', views.index), ] 创建index函数 def index(request): """ 分页功能 :param request: :return: """ user_list = models.Uinfo.objects

Django自定制分页功能

URL: """django_paginner URL Configuration The `urlpatterns` list routes URLs to views. For more information please see: https://docs.djangoproject.com/en/2.1/topics/http/urls/ Examples: Function views 1. Add an import: from my_app import vi

django之分页

分页 在当前网页如果特别的数据,如果不想当前网页显示太多的内容数据(例如一些文章的目录或者一些小说的章节目录很多地方都用到分页),这时候就需要用分页了. 在Django中数据被分在不同页面中,并带有“上一页/下一页”标签.这些类位于django/core/paginator.py中. 分页器Paginator Paginator.py源码 import collections from math import ceil from django.utils import six from djan

django的分页--不全也未实现

一.Django内置分页 Paginator 二.自定义分页 分页功能在每个网站都是必要的,对于分页来说,其实就是根据用户的输入计算出应该在数据库表中的起始位置. 1.设定每页显示数据条数 2.用户输入页码(第一页.第二页...) 3.根据设定的每页显示条数和当前页码,计算出需要取数据表的起始位置 4.在数据表中根据起始位置取值,页面上输出数据 需求又来了,需要在页面上显示分页的页面.如:[上一页][1][2][3][4][5][下一页] 1.设定每页显示数据条数 2.用户输入页码(第一页.第二