django基础之day08,分页器从无到有,动态思路解析全过程
*********分页器从无到有的全过程,动态思路解析如下:********
1.通过book_queryset = models.Book.objects.all()[start_num:end_num]
获取到用户在Book表中的所有数据,通过切片操作,获取用户的起始位数和终止位数
2.通过get请求方式,获取用户当前在第几页,current_page,默认在第一页
3.定义每页展示的条数pagenum=10
获得三者之间的对应关系:
startnum = (current_page-1) * pagenum
endnum = currentpage * pagenum
4.遇到问题,用户想要哪一页不能自己手动选择,我们只写死了5页的数据,
不够符合业务需求,此时我们想到了要加一个分页器,在底部放置。
5.下面开始了分组的逻辑运算;
5.1我们先要获取到数据表中总共有多少条数据
5.2计算出来数据表中数据的总条数
5.3通过all_page_num,more = divmod(总条数,每页数量),进行解压赋值操作
[divmod(a,b)方法可以用来查看所需要的分组是多少]
5.4 if more != 0: #此处也可以写成if more:代表有值,老师的写法
获取到了总共的页码数量:all_page_num +=1
5.5后端通过空字符串:html=''
循环总页码all_page_num次:for i in range(all_page_num):
这样html字符串进行连续的拼接:html += '<li><a href="?page=%s">%s</a></li>'%(i,i)
5.6然后通过渲染方法,把后端代码html字符串渲染到前端页面上,
通过safe模式{{ html|safe }}渲染代码,安全打开。
6.但是此时我们还是会遇到一个问题,就是把所有的页码全部展示出来了,
不符合用户规范和使用的需求,那么我们下一步该如何进行优化呢?
6.1我们想要一共展示11位的页码,我们采取
for循环当前页-5页和当前页+5页的一个范围,作为此次的改进,
html=''
for i in range(current_page-5,current_page+5):
html += '<li><a href="?page=%s">%s</a></li>'%(i,i)
6.2高亮显示用户选择的页码,怎么做呢?
思路:
1.判断用户当前的页码(浏览器url地址中的页码:current_page 变量)
和点击的页面页码是否相等 (鼠标移动的页面页码:i 变量)
如果两者相等:<li>标签中加入class="active",
两者不相等,<li>标签中不加入。
2.页码必须从1开始,该如何设置呢?
思路:举例子即可,当前页current_page赋值给变量XXX,
例如当前页current_page是第三页,第三页小于6,那么变量XXX=6,
程序往下继续执行,循环范围依然是从6-5=1开始,到11结束。
html='' #空字符串
xxx=current_page
if current_page < 6:
xxx=6
# 改进为采取for循环当前页-5页和当前页+5页的一个范围
for i in range(xxx-5,xxx+6): #顾头不顾尾,所以右边取到6
if current_page == i:
#这样html字符串进行连续的拼接
html += '<li class="active"><a href="?page=%s">%s</a></li>'%(i,i)
else:
html += '<li><a href="?page=%s">%s</a></li>'%(i,i)
********************************************************************************************************************
代码如下代码如下
********************************************************************************************************************
models.py文件
#批量插入数据,制作分页器作业
class Book(models.Model):
title=models.CharField(max_length=32)
def __str__(self):
return self.title
urls.py文件
from django.conf.urls import url
from django.contrib import admin
from app01 import views
urlpatterns = [
url(r'^admin/', admin.site.urls),
#首页
url(r'^$', views.home),
#访问该url就会往book表中插入1000条数据
url(r'^index/', views.index),
]
views.py文件
def index(request):
# 定义一页展示的条数
per_page_num=10
#拿出来数据表中所有的数据
book_queryset = models.Book.objects.all()
#计算出来数据表中数据的总条数
all_count=book_queryset.count()
#通过divmod(总数,每页数量)获得需要的总页码,进行解压赋值操作
# [divmod()方法可以用来查看所需要的分组是多少]
all_page_num,more=divmod(all_count,per_page_num)
# 用户查看的当前页码,默认为第一页,下面是三个变量之间的关系
current_page = request.GET.get('page', 1) # 当前页
current_page = int(current_page)
start_num = (current_page - 1) * per_page_num
end_num = current_page * per_page_num
if more != 0: #此处也可以写成if more:代表有值的条件
#获取到了总共的页码数量
all_page_num +=1
html='' #空字符串
xxx=current_page
if current_page < 6:
xxx=6
# 改进为采取for循环当前页-5页和当前页+5页的一个范围
for i in range(xxx-5,xxx+6): #顾头不顾尾,所以右边取到6
if current_page == i:
#这样html字符串进行连续的拼接
html += '<li class="active"><a href="?page=%s">%s</a></li>'%(i,i)
else:
html += '<li><a href="?page=%s">%s</a></li>'%(i,i)
#对数据表中的数据进行切分操作
book_queryset=book_queryset[start_num:end_num]
return render(request,'index.html',locals())
index.html文件
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>index页面批量插入数据作业</title>
<script src="https://cdn.bootcss.com/jquery/3.4.1/jquery.min.js"></script>
<link href="https://cdn.bootcss.com/twitter-bootstrap/3.3.1/css/bootstrap.min.css" rel="stylesheet">
<script src="https://cdn.bootcss.com/twitter-bootstrap/3.3.1/js/bootstrap.min.js"></script>
</head>
<body>
<div class="container-fluid">
<div class="row">
<div class="col-md-8 col-md-offset-2">
{% for book in book_queryset %}
<p>{{ book.title }}</p>
{% endfor %}
<nav aria-label="Page navigation">
<ul class="pagination">
<li>
<a href="#" aria-label="Previous">
<span aria-hidden="true">«</span>
</a>
</li>
{{ html|safe }}
<li>
<a href="#" aria-label="Next">
<span aria-hidden="true">»</span>
</a>
</li>
</ul>
</nav>
</div>
</div>
</div>
</body>
</html>
django基础之day08,分页器从无到有,动态思路解析全过程的更多相关文章
- django基础之day08,ajax结合sweetalert的使用
models.py文件 from django.db import models class User(models.Model): username=models.CharField(max_len ...
- Django基础之自定义分页器
自定义分页器 针对批量插入的数据,我们在前端展示的时候发现一个很严重的问题,一页展示了所有的数据,数据量太大,查看不方便 针对数据量大但又需要全部展示给用户观看的情况下,我们统一做法都是做分页处理 分 ...
- django基础之day08,利用bulk_create 批量插入成千上万条数据
bulk_create批量插入数据 models.py文件 class Book(models.Model): title=models.CharField(max_length=32) urls.p ...
- Django基础之命名URL和URL反向解析
在使用Django项目时,一个常见的需求是获得URL的最终形式,以用于嵌入到生成的内容中(视图中和显示给用户的URL等)或者用于处理服务器端的导航(重定向等). 人们强烈希望不要硬编码这些URL(费力 ...
- Django 基础教程
Django 基础教程 这是第一篇 Django 简介 » Django 是由 Python 开发的一个免费的开源网站框架,可以用于快速搭建高性能,优雅的网站! 你一定可以学会,Django 很简单 ...
- python的django基础篇
一.Django基础 Django 是用Python开发的一个免费开源的Web框架,可以用于快速搭建高性能,优雅的网站! Django的特点: 强大的数据库功能:拥有强大的数据库操作接口(QueryS ...
- Python学习(二十六)—— Django基础一
转载自:http://www.cnblogs.com/liwenzhou/p/8258992.html 一.Web框架本质 我们可以这样理解:所有的Web应用本质上就是一个socket服务端,而用户的 ...
- Django基础(一)
Django基础(一) 知识预览 Django基本命令 二 路由配置系统(URLconf) 三 编写视图 四 Template 五 数据库与ORM admin的配置 一 什么是web框架? 框架,即f ...
- python3之Django基础篇
一.Django基础 Django 是用Python开发的一个免费开源的Web框架,可以用于快速搭建高性能,优雅的网站! Django的特点: 强大的数据库功能:拥有强大的数据库操作接口(QueryS ...
随机推荐
- 【Luogu P1981】表达式求值
点我进入原题Luogu P1981 [解题思路] 仔细分析题目,这就是一道模拟题…… 直接按照符号读入全部的数字,先算乘法,最后把全部数加起来就是结果了 记得要%10000取最后四位 [参考程序] # ...
- vi指令详解
★ vi的模式(命令模式.插入模式.ex模式) 1)命令模式: 在我们刚刚通过vi新建或打开一个已经存在的文件时,首先默认被读取的模式就是“命令模式”,命令模式的特征就是,在编辑器窗口左下角的位置上没 ...
- Python执行系统命令的四种方法
一.os.system方法 在子终端运行系统命令,可以获取命令执行后的返回信息以及执行返回的状态.执行后返回两行结果,第一行是结果, 第二行是执行状态信息,如果命令成功执行,这条语句返回0,否则返回1 ...
- node.js+react全栈实践
利用业余时间写了个简单的项目,使用react+node.js做的一个全栈实践项目,前端参考了[React-Admin-Starter](https://github.com/veryStarters/ ...
- 01 JavaScript变量的声明、变量的使用、变量的命名规范和规则
变量的声明,关键字:var //声明一个变量 var name; //给变量赋值 name = '哈士奇'; //声明并赋值一个变量 var name = '哈士奇'; 变量的使用 //声明并赋值一个 ...
- 【C/C++】之C/C++快速入门
1 基本数据类型 C/C++语言中的基本数据类型及其属性如下表所示: 类型 取值范围 大致范围 整形 int -2147483648 ~ +2147483647 (即-231 ~ +(231-1 ...
- 运维常用 MySQL 命令
目录 设置用户密码 方法一 方法二 丢失root密码找回 添加用户 设置用户密码 方法一 SET PASSWORD FOR 'root'@'localhost' = PASSWORD('NewPass ...
- css实现input表单验证
有没有办法只通过css来确定input标签是否有输入? 我有这个想法是因为我想完成一个自动补全的input部件,最基本的功能是: 如果input没有内容,这隐藏下拉框 反之,显示下拉框 我找到了一个也 ...
- Python-TCP客户端程序开发
TCP客户端,需要与服务端建立连接,连接建立成功后才可以进行数据的传输. # 1.导入模块 import socket if __name__ == '__main__': # 2.创建套接字对象 t ...
- iOS开发之UIWebView
转自:http://www.cnblogs.com/zhuqil/archive/2011/07/28/2119923.html UIWebView是iOS sdk中一个最常用的控件.是内置的浏览器控 ...