Python - Django - 添加首页尾页上一页下一页

添加首页和尾页:

views.py:

from django.shortcuts import render
from app01 import models

def book_list(request):
    # 从 URL 中取参数
    page_num = request.GET.get("page")
    print(page_num, type(page_num))
    page_num = int(page_num)

    # 定义两个变量保存数据从哪儿取到哪儿
    data_start = (page_num - 1) * 10
    data_end = page_num * 10

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

    # 每一页显示多少条数据
    per_page = 10

    # 总共需要多少页码来显示
    total_page, m = divmod(total_count, per_page)

    # 页面上最多展示的页码
    max_page = 11
    half_max_page = max_page // 2

    # 页面上展示的页码的开始页
    page_start = page_num - half_max_page
    # 页面上展示的页码的结束页
    page_end = 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

    # 如果还有数据
    if m:
        total_page += 1

    all_book = models.Book.objects.all()[data_start:data_end]

    # 拼接 html 的分页代码
    html_list = []

    # 添加首页按钮
    html_list.append(‘<li><a href="/books/?page=1">首页</a></li>‘)

    # 展示的页码
    for i in range(page_start, page_end + 1):
        tmp = ‘<li><a href="/book_list/?page={0}">{0}</a></li>‘.format(i)
        html_list.append(tmp)

    # 添加尾页按钮
    html_list.append(‘<li><a href="/books/?page={}">尾页</a></li>‘.format(total_page))

    page_html = "".join(html_list)  # 拼接 html 的分页代码

    return render(request, "book_list.html", {"books": all_book, "page_html": page_html})

book_list.html:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>书籍列表</title>
    <link rel="stylesheet" href="/static/bootstrap/css/bootstrap.min.css">
</head>
<body>

<div class="container">

    <table class="table table-bordered">
        <thead>
        <tr>
            <th>序号</th>
            <th>id</th>
            <th>书名</th>
        </tr>
        </thead>
        <tbody>
        {% for book in books %}
            <tr>
                <td>{{ forloop.counter }}</td>
                <td>{{ book.id }}</td>
                <td>{{ book.title }}</td>
            </tr>
        {% endfor %}

        </tbody>
    </table>

    <nav aria-label="Page navigation">
        <ul class="pagination">
            <li>
                {{ page_html|safe }}
            </li>
        </ul>
    </nav>

</div>

</body>
</html>

运行结果:

添加上一页、下一页:

views.py:

from django.shortcuts import render
from app01 import models

def book_list(request):
    # 从 URL 中取参数
    page_num = request.GET.get("page")
    print(page_num, type(page_num))
    page_num = int(page_num)

    # 定义两个变量保存数据从哪儿取到哪儿
    data_start = (page_num - 1) * 10
    data_end = page_num * 10

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

    # 每一页显示多少条数据
    per_page = 10

    # 总共需要多少页码来显示
    total_page, m = divmod(total_count, per_page)

    # 页面上最多展示的页码
    max_page = 11
    half_max_page = max_page // 2

    # 页面上展示的页码的开始页
    page_start = page_num - half_max_page
    # 页面上展示的页码的结束页
    page_end = 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

    # 如果还有数据
    if m:
        total_page += 1

    all_book = models.Book.objects.all()[data_start:data_end]

    # 拼接 html 的分页代码
    html_list = []

    # 添加首页按钮
    html_list.append(‘<li><a href="/book_list/?page=1">首页</a></li>‘)

    # 如果是第一页,就没有上一页
    if page_num <= 1:
        html_list.append(‘<li class="disabled"><a href="#"><span aria-hidden="true">«</span></a></li>‘.format(page_num-1))
    else:
        # 加一个上一页的标签
        html_list.append(‘<li><a href="/book_list/?page={}"><span aria-hidden="true">«</span></a></li>‘.format(page_num-1))

    # 展示的页码
    for i in range(page_start, page_end + 1):
        # 给当前页添加 active
        if i == page_num:
            tmp = ‘<li class="active"><a href="/book_list/?page={0}">{0}</a></li>‘.format(i)
        else:
            tmp = ‘<li><a href="/book_list/?page={0}">{0}</a></li>‘.format(i)
        html_list.append(tmp)

    # 如果是最后一页,就没有下一页
    if page_num >= total_page:
        html_list.append(‘<li class="disabled"><a href="#"><span aria-hidden="true">»</span></a></li>‘)
    else:
        html_list.append(‘<li><a href="/book_list/?page={}"><span aria-hidden="true">»</span></a></li>‘.format(page_num+1))

    # 添加尾页按钮
    html_list.append(‘<li><a href="/book_list/?page={}">尾页</a></li>‘.format(total_page))

    page_html = "".join(html_list)  # 拼接 html 的分页代码

    return render(request, "book_list.html", {"books": all_book, "page_html": page_html})

book_list.html:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>书籍列表</title>
    <link rel="stylesheet" href="/static/bootstrap/css/bootstrap.min.css">
</head>
<body>

<div class="container">

    <table class="table table-bordered">
        <thead>
        <tr>
            <th>序号</th>
            <th>id</th>
            <th>书名</th>
        </tr>
        </thead>
        <tbody>
        {% for book in books %}
            <tr>
                <td>{{ forloop.counter }}</td>
                <td>{{ book.id }}</td>
                <td>{{ book.title }}</td>
            </tr>
        {% endfor %}

        </tbody>
    </table>

    <nav aria-label="Page navigation">
        <ul class="pagination">
            <li>
                {{ page_html|safe }}
            </li>
        </ul>
    </nav>

</div>

</body>
</html>

运行结果:

后续改进:

处理用户传给 url 的 page 参数异常的值的情况

例如:

访问,/127.0.0.1:8888/book_list/?page=a

访问,/127.0.0.1:8888/book_list/?page=-1

都会出错

改进:

from django.shortcuts import render
from app01 import models

def book_list(request):
    # 从 URL 中取参数
    page_num = request.GET.get("page")
    print(page_num, type(page_num))  # page_num 为 str 类型

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

    # 每一页显示多少条数据
    per_page = 10

    # 总共需要多少页码来显示
    total_page, m = divmod(total_count, per_page)

    # 如果还有数据
    if m:
        total_page += 1
    try:
        page_num = int(page_num)
        # 如果输入的页码数超过了最大的页码数,默认返回最后一页
        if page_num > total_page:
            page_num = total_page
        # 如果输入的页码数小于 1,则返回第一页
        if page_num < 1:
            page_num = 1
    except Exception as e:
        # 当输入的页码不是正经数字的时候 默认返回第一页的数据
        page_num = 1

    # 定义两个变量保存数据从哪儿取到哪儿
    data_start = (page_num - 1) * 10
    data_end = page_num * 10

    # 页面上最多展示的页码
    max_page = 11
    half_max_page = max_page // 2

    # 页面上展示的页码的开始页
    page_start = page_num - half_max_page
    # 页面上展示的页码的结束页
    page_end = 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

    all_book = models.Book.objects.all()[data_start:data_end]

    # 拼接 html 的分页代码
    html_list = []

    # 添加首页按钮
    html_list.append(‘<li><a href="/book_list/?page=1">首页</a></li>‘)

    # 如果是第一页,就没有上一页
    if page_num <= 1:
        html_list.append(‘<li class="disabled"><a href="#"><span aria-hidden="true">«</span></a></li>‘.format(page_num-1))
    else:
        # 加一个上一页的标签
        html_list.append(‘<li><a href="/book_list/?page={}"><span aria-hidden="true">«</span></a></li>‘.format(page_num-1))

    # 展示的页码
    for i in range(page_start, page_end + 1):
        # 给当前页添加 active
        if i == page_num:
            tmp = ‘<li class="active"><a href="/book_list/?page={0}">{0}</a></li>‘.format(i)
        else:
            tmp = ‘<li><a href="/book_list/?page={0}">{0}</a></li>‘.format(i)
        html_list.append(tmp)

    # 如果是最后一页,就没有下一页
    if page_num >= total_page:
        html_list.append(‘<li class="disabled"><a href="#"><span aria-hidden="true">»</span></a></li>‘)
    else:
        html_list.append(‘<li><a href="/book_list/?page={}"><span aria-hidden="true">»</span></a></li>‘.format(page_num+1))

    # 添加尾页按钮
    html_list.append(‘<li><a href="/book_list/?page={}">尾页</a></li>‘.format(total_page))

    page_html = "".join(html_list)  # 拼接 html 的分页代码

    return render(request, "book_list.html", {"books": all_book, "page_html": page_html})

如果数据库中的数据数少于 max_page,则会显示负数的页数

例如数据库中只有 21 条数据:

改进:

from django.shortcuts import render
from app01 import models

def book_list(request):
    # 从 URL 中取参数
    page_num = request.GET.get("page")
    print(page_num, type(page_num))  # page_num 为 str 类型

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

    # 每一页显示多少条数据
    per_page = 10

    # 总共需要多少页码来显示
    total_page, m = divmod(total_count, per_page)

    # 如果还有数据
    if m:
        total_page += 1
    try:
        page_num = int(page_num)
        # 如果输入的页码数超过了最大的页码数,默认返回最后一页
        if page_num > total_page:
            page_num = total_page
        # 如果输入的页码数小于 1,则返回第一页
        if page_num < 1:
            page_num = 1
    except Exception as e:
        # 当输入的页码不是正经数字的时候 默认返回第一页的数据
        page_num = 1

    # 定义两个变量保存数据从哪儿取到哪儿
    data_start = (page_num - 1) * 10
    data_end = page_num * 10

    # 页面上最多展示的页码
    max_page = 11
    # 如果总页码数小于页面上最多展示的页码
    if total_page < max_page:
        max_page = total_page
    half_max_page = max_page // 2

    # 页面上展示的页码的开始页
    page_start = page_num - half_max_page
    # 页面上展示的页码的结束页
    page_end = 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

    all_book = models.Book.objects.all()[data_start:data_end]

    # 拼接 html 的分页代码
    html_list = []

    # 添加首页按钮
    html_list.append(‘<li><a href="/book_list/?page=1">首页</a></li>‘)

    # 如果是第一页,就没有上一页
    if page_num <= 1:
        html_list.append(‘<li class="disabled"><a href="#"><span aria-hidden="true">«</span></a></li>‘.format(page_num-1))
    else:
        # 加一个上一页的标签
        html_list.append(‘<li><a href="/book_list/?page={}"><span aria-hidden="true">«</span></a></li>‘.format(page_num-1))

    # 展示的页码
    for i in range(page_start, page_end + 1):
        # 给当前页添加 active
        if i == page_num:
            tmp = ‘<li class="active"><a href="/book_list/?page={0}">{0}</a></li>‘.format(i)
        else:
            tmp = ‘<li><a href="/book_list/?page={0}">{0}</a></li>‘.format(i)
        html_list.append(tmp)

    # 如果是最后一页,就没有下一页
    if page_num >= total_page:
        html_list.append(‘<li class="disabled"><a href="#"><span aria-hidden="true">»</span></a></li>‘)
    else:
        html_list.append(‘<li><a href="/book_list/?page={}"><span aria-hidden="true">»</span></a></li>‘.format(page_num+1))

    # 添加尾页按钮
    html_list.append(‘<li><a href="/book_list/?page={}">尾页</a></li>‘.format(total_page))

    page_html = "".join(html_list)  # 拼接 html 的分页代码

    return render(request, "book_list.html", {"books": all_book, "page_html": page_html})

运行结果:

原文地址:https://www.cnblogs.com/sch01ar/p/11332864.html

时间: 2024-10-08 13:40:44

Python - Django - 添加首页尾页上一页下一页的相关文章

Android ListView上拉获取下一页

关于ListView上拉刷新的需求很多,实现方式也多种多样. 一般是简单的通过一个page变量来控制当前请求的页数,然后上拉的时候就发送请求. 实现出来后,经过测试哥的折腾,发现有诸多细节没有处理好,比如会出现重复数据,反复的上拉导致多次请求等bug. 后来就决定单独写一个工具类,方便以后需要直接使用. 1 public class ListViewScrollHelper<T> { 2 private static final String TAG = "ListViewScrol

Python+Django+SAE系列教程7-----在Sae上配置Django

本章的開始首先我们来注冊一个sae账号,首先登录http://sae.sina.com.cn/.进入登录页面,这里须要一个新浪微博账号进行注冊.假设没有赶快去注冊一个吧. 登录平台后.会提示一个授权信息.点击授权就OK了. 这里须要注意的是,每个手机号码仅仅能注冊一个sae账号.看看这个注冊页就能够知道: 填写完毕以后还须要手机验证一下就能够完毕注冊了. 注冊完毕以后会出现一下界面,立即点击"创建应用": 接下来是选择应用的语言和类型.我们选择python的web应用: 这里面让输入的

python django添加静态资源

在setting中确认以下: STATIC_URL = '/static/' 将静态目录放到app下,在app中创建static目录,然后再创建css.js.image. 在html中添加静态资源的路径: {% load staticfiles %} <link rel="stylesheet" href="{% static 'css/main.css' %}" /> 载入图片的方式和以上差不多,只要把static目录添加就好: <img src

python - django 使用ajax将图片上传到服务器并渲染到前端

一.前端代码 <!doctype html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <script> // 创建一个表单对象(用于存储要发送的data数据) form_data = new FormData; // 参数1:后端请求时要获取的参数, 参数

Python Django撸个WebSSH操作Kubernetes Pod(下)- 终端窗口自适应Resize

追求完美不服输的我,一直在与各种问题斗争的路上痛并快乐着 上一篇文章Django实现WebSSH操作Kubernetes Pod最后留了个问题没有解决,那就是terminal内容窗口的大小没有办法调整,这会导致的一个问题就是浏览器上可显示内容的区域太小,当查看/编辑文件时非常不便,就像下边这样,红色可视区域并没有被用到 RESIZE_CHANNEL 前文说到kubectl exec有两个参数COLUMNS和LINES可以调整tty内容窗口的大小,命令如下: kubectl exec -i -t

python下用selenium的webdriver包如何在执行完点击下一页后没有获得下一页新打开页面的html源代码

问题描述: 新打开的页面url不变,只是网页内容变了,然后使用drive.page_source得到的都是第一页的html代码,并不是当前页面的html代码. 1.  原因:webdriver仍默认在原页面下获取标签等信息: 解决方法:采用切换页面句柄的方式解决: 2.  原因:缺少time.sleep(1),如果短了就无法正常获取数据,所以检查适当位置是否有停留 def get_info(num): driver.get(url) driver.implicitly_wait(10) # 隐式

从零开始部署Django生产环境(适用:《跟老齐学Python Django实战》)

<跟老齐学Python Django实战>作为市面上少有的Django通俗实战书籍,给了我学习Django很大的帮助.作为一名新入门的菜鸟,全书我重复练习了至少三遍,每次都有新的收获. 前两次我选用了跟原书作者一致的Python和Django版本,只要保证代码没"抄错",基本不会有什么问题.第三次使用了更新的"Django==2.1.1",在路由urls.py配置中发现了不少问题,并一一改正. 写此博文,纪念自己的学习成果,并向作者qi sir致敬! 我

织梦只调用上一页下一页链接不要其他

//打开织梦系统文件 /include/arc.archives.class.php 找到GetPreNext函数 function GetPreNext($gtype='') { $rs = ''; if(count($this->PreNext)<2) { $aid = $this->ArcID; $preR = $this->dsql->GetOne("Select id From `#@__arctiny` where id<$aid And arcr

Extjs RowNumberer下一页动态增加

使用RowNumberer,当跳到下一页时,还是从1还是计数. 实现了序号的自动增加. ExtJs Grid分页时,默认情况下每页的序号都是从1起始的,这往往不符合我们的习惯.这里实现了序号的自动增加. 实现步骤如下: 1.定义全局变量. var record_start = 0; 2.Grid的columns部分的定义. columns : [new Ext.grid.RowNumberer({ header : "序号", width : 40, renderer:function