#分页例子
from django.core.paginator import Paginator
def blog_list(request):
      blog_all_list = models.Blog.objects.all()
      paginator = Paginator(blog_all_list,1) #10个一页 进行分页
      page_num = request.GET.get('page', 1) #获取url页面参数 没有默认显示第一页
      page_of_blogs = paginator.get_page(page_num)

context = {}
      context['page_of_blogs'] = page_of_blogs #得到每页的数据
      context['blog_types'] = models.BlogType.objects.all()
      # context['blogs_count'] =models.Blog.objects.all().count()
      return render_to_response('blog_list.html', context)

#分页html代码
-- 分页页码样式和标签采用bootstrap的例子做的
-- 连接是https://v3.bootcss.com/components/#pagination
<nav aria-label="Page navigation">
    <ul class="pagination">
      <li>
        <!-- 上一页 -->
        {% if page_of_blogs.has_previous %} <!-- 是否有上一页 -->
           <a href="?page={{ page_of_blogs.previous_page_number }}" aria-label="Previous">
             <span aria-hidden="true">&laquo;</span>
          </a>
       {% else %}
          <!-- <span aria-hidden="true">&laquo;</span> -->
       {% endif %}
     </li>
        {% for page_num in page_of_blogs.paginator.page_range %}
           <li><a href="?page={{ page_num }}">{{ page_num }}</a></li>
        {% endfor %}
     <li>
       <!-- 下一页 -->
      {% if page_of_blogs.has_next %} <!-- 是否有下一页 -->
         <a href="?page={{ page_of_blogs.next_page_number }}" aria-label="Next">
         <span aria-hidden="true">&raquo;</span>
        </a>
      {% else %}
         <!-- <span aria-hidden="true">&raquo;</span> -->
      {% endif %}
     </li>
   </ul>
</nav>

#总结
向前段传递分页对象page_of_blogs
对象属性:

- page_of_blogs.num_pages                    总页数 (最后一页)
                 - page_of_blogs.has_previous                    是否有上一页
                 - page_of_blogs.previous_page_number   上一页页数
                 - page_of_blogs.has_next                           是否有下一页
                 - page_of_blogs.next_page_number          下一页页数

判断上一页下一页代码:
-- 是否有下一页如果有就输出上一页图标
{% if page_of_blogs.has_next %}
    <a href="?page={{ page_of_blogs.next_page_number }}" aria-label="Next">
          <span aria-hidden="true">&raquo;</span>
   </a>
{% else %}
-- 如果没有可以输出一个空或者输出一个没有a便签的图标
       <!-- <span aria-hidden="true">&raquo;</span> -->
{% endif %}

#完整代码  包括上一页 下一页 首页 尾页
<nav aria-label="Page navigation">
<ul class="pagination">
<li>
<!-- 上一页 -->
{% if page_of_blogs.has_previous %} <!-- 是否有上一页 -->
<a href="?page=1" aria-label="Previous">
<span aria-hidden="true">首页</span>
</a>
<a href="?page={{ page_of_blogs.previous_page_number }}" aria-label="Previous">
<!-- <span aria-hidden="true">&laquo;</span> -->
<span aria-hidden="true">上一页</span>
</a>
{% else %}
<!-- <a href="?page=1" aria-label="Previous">
<span aria-hidden="true">首页</span>
</a> -->
{% endif %}
</li>
{% for page_num in page_of_blogs.paginator.page_range %}
<li><a href="?page={{ page_num }}">{{ page_num }}</a></li>
{% endfor %}
<li>
<!-- 下一页 -->
{% if page_of_blogs.has_next %} <!-- 是否有下一页 -->
<a href="?page={{ page_of_blogs.next_page_number }}" aria-label="Next">
<!-- <span aria-hidden="true">&raquo;</span> -->
<span aria-hidden="true">下一页</span>
</a>
<a href="?page={{ page_of_blogs.paginator.num_pages }}" aria-label="Next">
<span aria-hidden="true">尾页</span>
</a>
{% else %}
<!-- <span aria-hidden="true">&raquo;</span> -->
<!-- <a href="?page={{ page_of_blogs.end_index }}" aria-label="Next">
<span aria-hidden="true">尾页</span>
</a> -->
{% endif %}
</li>
</ul>
</nav>

效果:

Django2.0 分页的应用的更多相关文章

  1. 《玩转Django2.0》读书笔记-Django建站基础

    <玩转Django2.0>读书笔记-Django建站基础 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.网站的定义及组成 网站(Website)是指在因特网上根据一 ...

  2. Python3.7+Django2.0.4配合Mongodb打造高性能高扩展标签云存储方案

    原文转载自「刘悦的技术博客」https://v3u.cn/a_id_141 书接上回,之前有一篇文章提到了标签云系统的构建:Python3.7+jieba(结巴分词)配合Wordcloud2.js来构 ...

  3. django2.0+linux服务器 ,如何让自己电脑访问

    这几天一直在搞这个服务器端口开放问题,来让自己电脑可以访问服务器下的django网页,今天终于弄好了~~~~~离成功又进了一步~~~~~ 1.首先,我们来开放一个linux服务器的端口(我开放了828 ...

  4. Django2.0中文文档

    title: Django2.0中文文档 tags: Python,Django,入沐三分 grammar_cjkRuby: true --- Django2.0版本已经发布了,我们先来看一个图片 从 ...

  5. python3下Django2.0配置最新xadmin详解

    1,打开pycharm,创建一个Django项目 2,安装Django,默认是最新版本,pip3 install -i https://pypi.douban.com/simple/ django 3 ...

  6. 【Python3.6+Django2.0+Xadmin2.0系列教程一】环境搭建及项目创建

    由于工作需要,接触了大半年时间的Django+xadmin框架,一直没空对这块对进行相关的梳理.最近在同事的怂恿下,就在这分享下笔者的学习及工作经验吧. 好了,话不多说,下面开始进入正题: 环境需求: ...

  7. Django:Python3.6.2+Django2.0配置MySQL

    持续学习Django中... Django默认使用的数据库是python自带的SQLlite3,但SQLlite并不适用于大型的项目,因此我将数据库换成了MySQL,下面介绍下Django如何配置数据 ...

  8. Django2.0版本 path与Django1.x版本url正则匹配问题

    Django1.x版本url正则匹配如下: Django2.0版本正则匹配则要导入re_path模块如下:

  9. Python 3之Django2部署(centos7+nginx+python3+django2.0)

    前置工具,系统为centos7.5,为了方便管理,可以安装宝塔免费版本 首先, yum install -y wget && wget -O install.sh http://dow ...

随机推荐

  1. 027 H5常用标签

    只记录一下比较有趣的知识点. 一:新标签 1.选项列表datalist <!DOCTYPE html> <html lang="en"> <head& ...

  2. (转)设置了RemoveIPC=yes 的RHEL7.2 会crash掉Oracle asm 实例和Oracle database实例

    设置了RemoveIPC=yes 的RHEL7.2  会crash掉Oracle asm 实例和Oracle database实例,该问题也会在使用Shared Memory Segment (SHM ...

  3. esxi上为基于LVM的centos7的根目录扩容

    概念:据说默认centos都是基于LVM的 LVM:LVM是逻辑盘卷管理(Logical Volume Manager)的简称,它是Linux环境下对磁盘分区进行管理的一种机制. LVM 更加详细的说 ...

  4. macos下如何解决无法写ntfs格式的u盘或硬盘?

    答:macos原生支持,可以通过脚本卸载再重新挂载为可读写即可,脚本在此

  5. Typescript 介绍和安装编译

    一. Typescript 介绍 1. TypeScript 是由微软开发的一款开源的编程语言. 2. TypeScript 是 Javascript 的超级,遵循最新的 ES6.Es5 规范.Typ ...

  6. 解决 service iptables save 报错 please try to use systemctl

    本文档根据 service iptables save 报错 please try to use systemctl 提供解决方案.报错 [root@Jaking ~]# service iptabl ...

  7. 安装ORACLE服务出现Oracle Net Configuration Assistant 失败问题【我】

    安装ORACLE服务出现Oracle Net Configuration Assistant 失败问题 本地安装oracle11g,报错提示: 参考下面文章: 报错原因: 主要是对文件系统的访问权限问 ...

  8. VS2015 dlib编译 x64 Debug .lib生成

    VS2015 dlib编译 x64 Debug >------ 已启动生成: 项目: ZERO_CHECK, 配置: Debug x64 ------ > Checking Build S ...

  9. React错误收集

    1.  Uncaught Error: Element type is invalid: expected a string (for built-in components) or a class/ ...

  10. mysql登录指令

    mysql -h 192.168.1.124 -u root -p -h后加mysql的ip,-u加用户名,-p会弹出输入密码