分页器(分页器基本操作、点击按钮分页、美化分页器)

更新时间:2023-07-11 10:34:58 阅读: 评论:0

分页器(分页器基本操作、点击按钮分页、美化分页器)分页器基本操作
⽤户访问⼀个⽹页或者查看某些数据,如果数据量过⼤肯定需要按页查看,不可能⼀个页⾯显⽰N条数据内容这⾥就⽤到了分页器⾸先往数据库⾥插⼊数据,这⾥咱们进⾏脚本批量插⼊
# #脚本批量插⼊数据
book_list = []
for i in range(200):
#创建200条数据
book = Book(title='book_%s'%i,price=i*i)
book_list.append(book)
#批量插⼊语法
Book.objects.bulk_create(book_list)
这样⼀条inrt语句包含多条数据,⼀次性插⼊
分页器的基本语法及使⽤
def index(request):
禁止公开学生成绩#分页器对使⽤
#book_list = Book.objects.all()
    #这⾥建议使⽤该种⽅法获取Book对象的列表,否则会出现 ‘UnorderedObjectListWarning: Pagination may yield inconsistent results with an unordered object_list:’
的报警信息。
book_list = _queryt().order_by('id')
paginator = Paginator(book_list,10) #多少数据分⼀页
print('coumt:',unt) #数据总数
print('num_pages:',paginator.num_pages) #总页数
print('page_range:',paginator.page_range) #页码列表
#获取某页的⽅式
#⽅式⼀
page1=paginator.page(1) #获取第⼀页的page对象fredo
#⽅式⼆
for i in page1: #遍历第⼀页的所有数据
advertiment是什么意思print(i)
#根据⽤户选择来进⾏页⾯显⽰,获取⽤户的页数
try: #这⾥捕获异常到⽬的就是为了⽤户选择页码以外到值不会报错
current_page=int(('page',1)) #这⾥要记得传⼀个默认值否则会报错,因为views 没有获取到page这个参数
current_page=paginator.page(current_page)
except EmptyPage as e:
current_page =paginator.page(1)
欲望都市2 下载return render(request,'index.html',locals())
#输出内容
coumt: 200
num_pages: 20
page_range: range(1, 21)
Book object (1)
Book object (2)
Book object (3)
Book object (4)
Book object (5)
Book object (6)
Book object (7)
Book object (8)
Book object (9)
Book object (10)
前端页⾯的显⽰,传递分页过后的对象
<!DOCTYPE html>
<html lang="en">
怎么治痘印
<head>
<meta chart="UTF-8">
<title>分页器</title>
</head>
<body>
<ul>
{#这⾥传递分页过后到内容#}topot
{% for book in current_page %}
<li>{{ book.title }} : {{ book.price  }}</li>
{% endfor %}
</ul>
</body>
</html>
效果图
英语文章朗读
因为默认访问显⽰的为第⼀页内容,如是果想访问其他页需要 给后端传递 page 参数
更换页码 URL
点击按钮分页
fuel是什么意思
这⾥就⽤到bootstrap了,⾸先引⼊cdn,加在bootstrap,bookstarp官⽹给出了分页器的模版,咱们可以直接拿过来⽤
<nav aria-label="Page navigation">
<ul class="pagination">
<li>
<a href="#" aria-label="Previous">
<span aria-hidden="true">«</span>
</a>
</li>
<li><a href="#">1</a></li>
<li><a href="#">2</a></li>
<li><a href="#">3</a></li>
英文自我介绍面试<li><a href="#">4</a></li>
<li><a href="#">5</a></li>
<li>
<a href="#" aria-label="Next">
<span aria-hidden="true">»</span>
</a>
</li>
</ul>
</nav>
这⾥他是写好的多少个li标签也就是多少页,咱们要根据后端的  paginator_num_pages  进⾏range 循环进⾏动态展⽰页码,并根据点击页码进⾏更改 ?page 的值,并对点击标签加深,
这⾥判断对是当前点击页⾯与后端获取页⾯是否相等,如果相等给予li 标签  calss =active 属性
{% for item in paginator.page_range%}
{% if current_num == item %}
<li class="active"><a href="?page={{ item }}">{{ item }}</a></li>沟通案例分析
{% el %}
<li><a href="?page={{ item }}">{{ item }}</a></li>
{% endif %}
显⽰效果
下⾯咱们配置上⼀页和下⼀页功能
{% if current_page.has_previous %}
<li><a href="?page={{ current_page.previous_page_number }}" aria-label="Previous"><span aria-hidden="true">上⼀页</span></a>
</li>
{% el %}
<li class="disabled"><a href="" aria-label="Previous"><span aria-hidden="true">上⼀页</span></a></li>
{% if current_page.has_next %}
<li><a href="?page={{ _page_number }}" aria-label="Next"><span
aria-hidden="true">下⼀页</span></a></li>
{% el %}
<li class="disabled"><a href="" aria-label="Previous"><span aria-hidden="true">下⼀页</span></a></li>
{% endif %}
这⾥如果不对当前页⾯进⾏判断是否还有上⼀页或者下⼀页
current_page.has_previous
current_page.has_next
就会出现上⼀页或者下⼀页不存在数据的序号,如果⽤户点击了下⼀页或者上⼀页,则给当前页⾯发送参数,分别意思为当前页⾯对上⼀页和当前页⾯对下⼀页
href="?page={{ current_page.previous_page_number }}
href="?page={{ _page_number }}
判断如果当前页⾯对上⼀页,或者下⼀页为最后⼀页,将li 标签设置 disabled 属性,变为不可点击
美化分页器
美化分页器
理想中对分页器是这样的,点击之后两边显⽰可点击的页码
⾸先咱们要对咱们的页数进⾏判断,超过多少页的时候可以进⾏左右两边划分,划分过后,要控制点击页码的两边的页码为正常数值,
如果两边的页码数量⼩于这个值,要对整体循环页码赋予新的值。
html

本文发布于:2023-07-11 10:34:58,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/fan/78/1090690.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:页码   数据   点击   获取   判断   相等
相关文章
留言与评论(共有 0 条评论)
   
验证码:
推荐文章
排行榜
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图