django的分页器Paginator 从django中导入类

作者:谷子的 时间:2022-02-07 04:24:29 

先创建表,然后生成批量数据。

在models文件里


from django.db import models

# Create your models here.

class Book(models.Model):

name = models.CharField(max_length=32)
 price = models.DecimalField(max_digits=5,decimal_places=2)

然后执行python manage.py makemigrations ,python migrate 生成数据库。把数据库从左边拉到右边,

在url里创建showBooks视图函数API,


from django.conf.urls import url
from django.contrib import admin

from app01 import views
urlpatterns = [
 url(r'^admin/', admin.site.urls),
 url(r'^index/', views.index),
 url(r'^ajaxHandle/', views.ajaxHandle),
 url(r'^showBooks/', views.showBooks),-------

在views文件中创建showBooks 函数,批量导入数据,用bulk_create()

从django中导入Paginstor类,用对象调用方法,


def showBooks(requests):

#批量导入数据bulk_create()方法

# book_list=[]#里面存一个个对象
 # for i in range(100):
 #   book_list.append(Book(name="book%s"%i,price=2+i+2))
 #
 # Book.objects.bulk_create(book_list)

book_list_all = Book.objects.all()

#分页器Paginator,是导入了一个类,在用实列出来的对象调用方法,
 from django.core.paginator import Paginator,EmptyPage,PageNotAnInteger

#book_list_all 是要被分页的对象,第二个参数,是每页显示的条数
 p = Paginator(book_list_all,20)# p就是每页的对象,
 p.count #数据总数
 p.num_pages #总页数
 p.page_range#[1,2,3,4,5],得到页码,动态生成,

page_num = requests.GET.get("page")#以get的方法从url地址中获取
 #如果输错了页码,
 try:
   book_list = p.page(page_num)#括号里的是页数,显示指定页码的数据,动态显示数据,所以不能写死了

except PageNotAnInteger:#如果输入页码错误,就显示第一页
   book_list = p.page(1)
 except EmptyPage:#如果超过了页码范围,就把最后的页码显示出来,
   book_list = p.page(p.num_pages)

return render(requests,"showBooks.html",locals())

数据库生成数据

django的分页器Paginator 从django中导入类

在templates 创建showBooks页面,把数据库数据渲染出来


{% load staticfiles %}
<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>Title</title>
 <link rel="stylesheet" href="{% static 'bootstrap/css/bootstrap.css' %}" rel="external nofollow" >

</head>
<body>

<ul>
{#request 也可以在这里渲染出来#}
 {% for book in book_list %}
   <li>{{ book.id }}&nbsp&nbsp&nbsp&nbsp&nbsp{{ book.name }}&nbsp&nbsp&nbsp&nbsp&nbsp{{ book.price }}</li>
 {% endfor %}

</ul>

<ul class="pagination">
    {% if book_list.has_previous %}
   <li><a href="/showBooks/?page={{ book_list.previous_page_number }}" rel="external nofollow" >上一页</a></li> ---直接使用方法,上一页,
   {% else %}
   <li class="disabled"><a href="#" rel="external nofollow" rel="external nofollow" >上一页</a></li>
    {% endif %}

{% for num in p.page_range %}
   <li><a href="/showBooks/?page={{ num }}" rel="external nofollow" >{{ num }}</a></li>
  {% endfor %}

{% if book_list.has_next %}
   <li><a href="/showBooks/?page={{ book_list.next_page_number }}" rel="external nofollow" >下一页</a></li>
  {% else %}
   <li class="disabled"><a href="#" rel="external nofollow" rel="external nofollow" >下一页</a></li>
   {% endif %}

</ul>
</body>
</html>

来源:https://www.cnblogs.com/gyh04541/p/7956109.html

标签:django,分页器,paginator,导入,类
0
投稿

猜你喜欢

  • SQL Server数据库的高性能优化经验总结

    2024-01-18 17:04:55
  • SQL语句练习实例之一——找出最近的两次晋升日期与工资额

    2011-10-24 20:16:42
  • python数据库操作指南之PyMysql使用详解

    2023-01-02 04:04:17
  • Python Multiprocessing多进程 使用tqdm显示进度条的实现

    2021-04-03 19:15:08
  • 如何不通过DSN访问SQL Server?

    2009-11-11 19:21:00
  • 深入理解 Python 中的多线程 新手必看

    2021-10-09 16:11:45
  • 基于vue打包后字体和图片资源失效问题的解决方法

    2024-05-05 09:12:13
  • python项目对接钉钉SDK的实现

    2021-09-18 22:21:29
  • JSP EL表达式详细介绍

    2023-07-02 22:32:32
  • python定时关机小脚本

    2022-09-24 23:38:21
  • vscode检测到#include错误请更新includePath的解决方法

    2022-10-14 22:58:04
  • go语言中的return语句

    2024-05-28 15:22:09
  • 理解HTTP消息头

    2008-12-10 14:06:00
  • mysql查询条件not in 和 in的区别及原因说明

    2024-01-27 12:41:49
  • Python match语句的具体使用

    2023-07-24 03:10:08
  • Golang并发利器sync.Once的用法详解

    2024-04-25 15:12:06
  • bootstrap-table+treegrid实现树形表格

    2024-04-29 13:12:53
  • 简单了解python单例模式的几种写法

    2022-01-16 20:05:51
  • 详解Python自动化之文件自动化处理

    2022-07-24 03:50:02
  • JavaScript条件判断_动力节点Java学院整理

    2024-04-22 22:24:50
  • asp之家 网络编程 m.aspxhome.com