一、视图CBV  

 1.urls
    url(r'^login.html$', views.Login.as_view()),
  2.views
    from django.views import View

    class Login(View):
      def get(self,request):
        return HttpResponse('from get')

      def post(self,request):
        return HttpResponse('from post')

二、ORM补充

  正向操作
    result = models.UserInfo.objects.all()
    for obj in result:
    print(obj.name,obj.age,obj.ut_id,obj.ut.title,obj.ut.fo.new_name)#通过点外键名进行连表操作ut和fo都是外键名
  反向操作
    obj = models.UserType.objects.all().first()
    print(obj.id,obj.title,obj.userinfo_set_all()) # obj.userinfo_set_all()匹配用户类型相关的所有用户

    for row in obj.userinfo_set_all(): #遍历每一个用户对象     print(row.name,row.age)

三、Django的自带分页

url(r'^index.html$', views.index),
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title></title>
</head>
<body>
<h1>用户列表</h1>
<ul> {# 每页显示10条信息 #}
{% for row in posts.object_list %}
<li>{{ row.name }}</li>
{% endfor %}
</ul> <div>
{% if posts.has_previous %} {# 如果有上一页,显示上一页的标签 #}
<a href="/index.html?page={{ posts.previous_page_number }}">上一页</a>
{% endif %} {% for num in posts.paginator.page_range %}
<a href="/index.html?page={{ num }}">{{ num }}</a>
{% endfor %} {% if posts.has_next %} {# 如果有下一页,显示上一页的标签 #}
<a href="/index.html?page={{ posts.next_page_number }}">下一页</a>
{% endif %}
</div>
</body>
</html>

index.html

from django.core.paginator import Paginator,Page,PageNotAnInteger,EmptyPage
def index(request):
"""
分页
:param request:
:return:
"""
# for i in range(300):
# name = "root" + str(i)
# models.UserInfo.objects.create(name=name,age=18,ut_id=1) current_page = request.GET.get('page') # URL中获取第几页 user_list = models.UserInfo.objects.all() # 数据库查询所有的数据
paginator = Paginator(user_list,10) # 页面显示出10条数据
# per_page: 每页显示条目数量
# count: 数据总个数
# num_pages:总页数
# page_range:总页数的索引范围,如: (1,10),(1,200)
# page: page对象
try:
posts = paginator.page(current_page) # 创建page对象
except PageNotAnInteger as e: # 发生异常则默认跳到第一页
posts = paginator.page(1)
except EmptyPage as e:
posts = paginator.page(1)
# has_next 是否有下一页
# next_page_number 下一页页码
# has_previous 是否有上一页
# previous_page_number 上一页页码
# object_list 分页之后的数据列表
# number 当前页
# paginator paginator对象
return render(request,'index.html',{'posts':posts})

View.py

四、Django的自定义分页

  前端模板

{# 通过视图函数传过来的user_list是指定页码之间的数据库数据 #}
{% for article in user_list %}
<div class="article-item" style="padding: 5px 0">
<div class="art-footer">
<a href="#" class="foot" onclick="updown(this,{{ article.nid }},1);">
<span class="glyphicon glyphicon-thumbs-up"></span> {# fa fa-thumbs-up点赞图标#}
点赞({{ article.up_count }}) {# 点赞个数#}
</a>
</div>
</div>
{% endfor %} {# 在引入bootstrap的css文件后,把下面的代码放到前端模板html指定位置,显示页码图标 #}
<nav aria-label="Page navigation">
<ul class="pagination">
{{ page_info.pager|safe }}
</ul>
</nav>

  后端视图函数处理

def func(request):
base_url = '/%s/%s/%s/' % (blog.user.username,key,val) # 获取到当前跳转页面的URL
article_list = models.Article.objects.filter(**conditions) #数据库查询到的所有数据
all_count = article_list.count() # 获取数据库中指定对象的总条数
# request.GET.get('page'):从URL中获取当前页 all_count:总条数 10:每页显示10条
page_info = PageInfo(request.GET.get('page'), all_count, 2, base_url, 11)
user_list = article_list[page_info.start():page_info.end()] # 每页显示的数据 return render(request,'index.html',
{
'user_list': user_list,
'page_info': page_info
})

  封装好的页码类处理

class PageInfo(object):
def __init__(self,current_page,all_count,per_page,base_url,show_page=11):
"""
:param current_page: 当前页
:param all_count: 数据库总行数
:param per_page: 每页显示函数
:return:
"""
try:
self.current_page = int(current_page) #把URL中获取到的当前页转换为数字
except Exception as e: # 转换出错则跳转到第一页
self.current_page = 1
self.per_page = per_page # 每页显示的条数 a,b = divmod(all_count,per_page) # 总条数除以每页条数获得一共有多少页
if b: # 如果有余数则证明剩下的不够每页显示的数目但是需要加一页
a = a +1
self.all_pager = a # all_pager 表示总页数
self.show_page = show_page # show_page 数据很多时显示11页
self.base_url = base_url # 传入要跳转的URL地址
def start(self): # 取文章数据的时候
return (self.current_page-1) * self.per_page # 当前页减一乘以每页显示的条数 第几条 def end(self):
return self.current_page * self.per_page # 当前页乘以每页显示的条数 到第几条 def pager(self):
page_list = []
# half是用来显示前五页和后五页的一个数
half = int((self.show_page-1)/2) # 显示的页码减一除以二 # 如果数据总页数 < 11
if self.all_pager < self.show_page:
begin = 1
stop = self.all_pager + 1
# 如果数据总页数 > 11
else:
# 如果当前页 <=5,永远显示1,11
if self.current_page <= half:
begin = 1
stop = self.show_page + 1
else:
if self.current_page + half > self.all_pager: #当前页加五后大于总页码的时候
begin = self.all_pager - self.show_page + 1 # 起始页为最后一页往前倒11页
stop = self.all_pager + 1 # 最后一页
else:
begin = self.current_page - half # 当前页往前倒5页
stop = self.current_page + half + 1 # 当前页往后倒5页 if self.current_page <= 1: # 当前页小于等于1时,上一页不能点
prev = "<li><a href='#'>上一页</a></li>"
else: # 当前页大于1时,上一页能点
prev = "<li><a href='%s?page=%s'>上一页</a></li>" %(self.base_url,self.current_page-1,)
page_list.append(prev) # 把标签放入列表中 for i in range(begin,stop):
if i == self.current_page: # 当前页等于i时证明当前页被选中加上active属性
temp = "<li class='active'><a href='%s?page=%s'>%s</a></li>" %(self.base_url,i,i,)
else:
temp = "<li><a href='%s?page=%s'>%s</a></li>" %(self.base_url,i,i,)
page_list.append(temp) # 把标签放入列表中 if self.current_page >= self.all_pager: # 当前页大于等于最后一页时,下一页不能点
nex = "<li><a href='#'>下一页</a></li>"
else:
nex = "<li><a href='%s?page=%s'>下一页</a></li>" %(self.base_url,self.current_page+1,)
page_list.append(nex) # 把标签放入列表中 return ''.join(page_list) # 返回一个拼接的字符串

  

django上课笔记2-视图CBV-ORM补充-Django的自带分页-Django的自定义分页的更多相关文章

  1. django上课笔记3-ORM补充-CSRF (跨站请求伪造)

    一.ORM补充 ORM操作三大难点: 正向操作反向操作连表 其它基本操作(包含F Q extra) 性能相关的操作 class UserInfo(models.Model): uid = models ...

  2. Django 基于类的视图(CBV)执行流程 CBV 源码分析

    一.CBV(基于类的视图) 视图是可以调用的,它接受请求并返回响应,这不仅仅是一个函数,Django提供了一些可以用作视图的类的例子,这些允许您通过继承或mixin来构建视图并重用代码. 基本示例 D ...

  3. Django学习笔记之视图高级-HTTP请求与响应

    Django限制请求method 常用的请求method GET请求 GET请求一般用来向服务器索取数据,但不会向服务器提交数据,不会对服务器的状态进行更改.比如向服务器获取某篇文章的详情. POST ...

  4. Django学习笔记之视图高级-类视图

    类视图 在写视图的时候,Django除了使用函数作为视图,也可以使用类作为视图.使用类视图可以使用类的一些特性,比如继承等. View django.views.generic.base.View是主 ...

  5. Django学习笔记〇四——数据库ORM的使用(有待修改)

    Django框架基本上都是要和数据库结合使用的,我在以前讲过SQLAlchemy框架的使用,Django支持的不是SQLAlchemy,但是也内嵌了ORM框架,可以不需要直接面对数据库编程,而可以通过 ...

  6. Django学习笔记(20)——BBS+Blog项目开发(4)Django如何使用Bootstrap

    本文学习如何通过Django使用Bootstrap.其实在之前好几个Django项目中已经尝试使用过了Bootstrap,而且都留有学习记录,我已经大概有了一个大的框架,那么本文就从头再走一遍流程,其 ...

  7. Django 分页组件替换自定义分页

    Django的分页器(paginator) 总之不太好用我们还是用自己的好一些 自定义分页器 分页实现源码 """ 自定义分页组件 """ ...

  8. django上课笔记1-目录介绍-路由系统-ORM操作

    一.Django目录介绍 django-admin startproject mysite # 创建名为mysite的项目 cd mysite # 切换到该目录下 python manage.py s ...

  9. Django学习笔记之视图高级-CSV文件生成

    生成CSV文件 有时候我们做的网站,需要将一些数据,生成有一个CSV文件给浏览器,并且是作为附件的形式下载下来.以下将讲解如何生成CSV文件. 生成小的CSV文件 这里将用一个生成小的CSV文件为例. ...

随机推荐

  1. Linux网络驱动架构

    网络设备介绍 网络设备是计算机体系结构中必不可少的一部分,处理器如果想与外界通信,通常都会选择网络设备作为通信接口.众所周知,在 OSI(Open Systems Interconnection,开放 ...

  2. BUPT复试专题—最值问题(2013计院)

    题目描述 给出N个数,求出这N个数中最大值和次大值.注意这里的次大值必须严格小于最大值.输入保证N个数中至少存在两个不同的数. 输入格式 第一行为测试数据的组数T(T≤20).请注意,任意两组测试数据 ...

  3. Hive 外部表 分区表

      之前主要研究oracle与mysql,认为hive事实上就是一种数据仓库的框架,也没有太多另类,所以主要精力都在研究hadoop.hbase,sqoop,mahout,近期略微用心看了下hive. ...

  4. PCA主成分分析Python实现

    作者:拾毅者 出处:http://blog.csdn.net/Dream_angel_Z/article/details/50760130 Github源代码:https://github.com/c ...

  5. Objective C运行时(runtime)技术总结,好强大的runtime

    前言:          Objective C的runtime技术功能非常强大,能够在运行时获取并修改类的各种信息,包括获取方法列表.属性列表.变量列表,修改方法.属性,增加方法,属性等等,本文对相 ...

  6. Django-权限信息初始化

    数据库 from django.db import models class Menu(models.Model): """ 菜单组: """ ...

  7. 文本分析实例---QQ聊天记录分析

    对QQ聊天记录进行分析,由于每天产生的聊天记录比較多,所以选取的是从2月份整月的聊天记录数据.分析要产生的结果有三个,聊天记录中发消息的人前top15.统计24小时时间段那个时间段发贴人最多,还有对消 ...

  8. backtrace、backtrace_symbols、backtrace_symbols_fd-support for application self-debugging

    backtrace是库函数引入的应用自调试函数. 系列里的三个函数可以缓冲或输出栈帧. #include <execinfo.h> int backtrace(void **buffer, ...

  9. 二阶段 三阶段 提交 Paxos

    关于分布式事务.两阶段提交协议.三阶提交协议 - 文章 - 伯乐在线 http://blog.jobbole.com/95632/

  10. TiDB 整体架构 结合yarn zookeeper分析架构

    TiDB 简介与整体架构| PingCAP https://www.pingcap.com/docs-cn/overview/ 真正金融级高可用 相比于传统主从 (M-S) 复制方案,基于 Raft ...