#分页例子
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. vim 显示行号 临时&永久

    设置vim 永久显示行号 - electrocrazy的博客 - CSDN博客https://blog.csdn.net/electrocrazy/article/details/79035216 v ...

  2. 【转】把sqlite3数据导入到MySQL中

    之前我们默认使用的是SQLite数据库,我们开发完成之后,里面有许多数据.如果我们想转换成Mysql数据库,那我们先得把旧数据从SQLite导出,然后再导入到新的Mysql数据库里去. 1.SQLit ...

  3. 004-行为型-07-备忘录模式(Memento)

    一.概述 又叫做快照模式(Snapshot Pattern)或Token模式 保存对象的内部状态,并在需要的时候(undo/rollback)恢复对象以前的状态. 意图:在不破坏封装性的前提下,捕获一 ...

  4. Spring cloud微服务安全实战-6-7jwt改造总结

    限流的改造. 同样注意,不要声明成Spring的Bean 在上面声明Rateliiter 如果能获取到权限继续往下走,没权限就返回,to many request的错误信息. 加到过滤器链上 加载Sp ...

  5. 关于Image模块的调色板

    参考:https://blog.csdn.net/zhangziju/article/details/79123275 https://blog.csdn.net/qq_21239003/articl ...

  6. IBM System x3650 M3_RAID服务器进入阵列卡配置界面(webBIOS)

    按 F1 进入 UEFI, 选择“System Settings”- “Adapters and UEFI Drivers”- “Please press ENTER to compile the l ...

  7. 【pip升级导致错误】 多个pip导致明明已经安装了包但是报no module错误

    原来一直用apt install 默认安装的pip 8.01版本,今天因为一些原因,将pip升级到了19.01.升级后就导致了错误. 直接pip installl --upgrade pip,发现报权 ...

  8. Win10下载安装PostgreSQL 11.1

    下载地址:https://get.enterprisedb.com/postgresql/postgresql-11.1-1-windows-x64.exe Installation Director ...

  9. robot:截图关键字

    参考: https://www.cnblogs.com/hong-fithing/p/9656221.html--python https://blog.csdn.net/weixin_4315628 ...

  10. js 验证手机号

    <script> var reg = /^1([38][0-9]|4[579]|5[0-3,5-9]|6[6]|7[0135678]|9[89])\d{8}$/; function ver ...