Django 4.x 智能分页get_elided_page_range

Django智能分页

分页效果

  • 第1页的效果
  • 第10页的效果
  • 带输入框的效果

主要函数

python 复制代码
# 参数解释
# number: 当前页码,默认:1
# on_each_side:当前页码前后显示几页,默认:3
# on_ends:首尾固定显示几页,默认:2
Paginator.get_elided_page_range(number, on_each_side=3, on_ends=2)

代码部分

  • 接口查询
python 复制代码
# 获取列表信息
def events(request):
	
	event_list = Event.objects.all().order_by("-level", "-begin")
	# 分页部分的代码
	page_number = request.GET.get('page', 1)
	paginator = Paginator(event_list, 15)
    page_obj = paginator.get_page(page_number)
    page_range = paginator.get_elided_page_range(number=page_number, on_each_side=3, on_ends=2)
    
    return render(request, "events.html", {"page_obj": page_obj, "page_range": page_range})
  • 前端展示
html 复制代码
...
{#分页代码,业务代码请自行补充即可#}
{% if page_obj.has_other_pages %}
  <nav>
    <ul class="pagination justify-content-center">
      {% if page_obj.has_previous %}
        <li class="page-item"><a class="page-link" href="?page={{ page_obj.previous_page_number }}">上一页</a></li>
      {% else %}
        <li class="page-item disabled"><a class="page-link" href="#">上一页</a></li>
      {% endif %}
      
      {% for item in page_range %}
          {% if item == page_obj.number %}
            <li class="page-item active"><a class="page-link" href="?page={{ item }}">{{ item }}</a></li>
          {% elif item == '...' %}
            <li class="page-item"><a class="page-link" href="#">{{ item }}</a></li>
          {% else %}
            <li class="page-item"><a class="page-link" href="?page={{ item }}">{{ item }}</a></li>
          {% endif %}
      {% endfor %}

      {% if page_obj.has_next %}
        <li class="page-item"><a class="page-link" href="?page={{ page_obj.next_page_number }}">下一页</a></li>
      {% else %}
        <li class="page-item disabled"><a class="page-link" href="#">下一页</a></li>
      {% endif %}
    </ul>
  </nav>
{% endif %}

带输入框的效果部分代码

  • 接口查询时添加了总页数
python 复制代码
def events(request):
	
	event_list = Event.objects.all().order_by("-level", "-begin")
	# 分页部分的代码
	page_number = request.GET.get('page', 1)
	paginator = Paginator(event_list, 15)
    page_obj = paginator.get_page(page_number)
    num_pages = paginator.num_pages  # 获取总共有多少页
    page_range = paginator.get_elided_page_range(number=page_number, on_each_side=3, on_ends=2)
    
    return render(request, "events.html", {"page_obj": page_obj, "page_range": page_range, "num_pages ":num_pages })
  • 前端部分添加了输入框
html 复制代码
{% if page_obj.has_other_pages %}
  <nav>
    <ul class="pagination justify-content-center">
      {% if page_obj.has_previous %}
        <li class="page-item"><a class="page-link" href="?page={{ page_obj.previous_page_number }}">上一页</a></li>
      {% else %}
        <li class="page-item disabled"><a class="page-link" href="#">上一页</a></li>
      {% endif %}
      
      {% for item in page_range %}
          {% if item == page_obj.number %}
            <li class="page-item active"><a class="page-link" href="?page={{ item }}">{{ item }}</a></li>
          {% elif item == '...' %}
            <li class="page-item"><a class="page-link" href="#">{{ item }}</a></li>
          {% else %}
            <li class="page-item"><a class="page-link" href="?page={{ item }}">{{ item }}</a></li>
          {% endif %}
      {% endfor %}

      {% if page_obj.has_next %}
        <li class="page-item"><a class="page-link" href="?page={{ page_obj.next_page_number }}">下一页</a></li>
      {% else %}
        <li class="page-item disabled"><a class="page-link" href="#">下一页</a></li>
      {% endif %}
      # 对input输入进行了限制[1, num_pages],防止越界输入# 
      <li class="page-item">&nbsp;共{{ num_pages }}页<label for="p_num">&nbsp;到第</label><input type="text" oninput="if(value>{{ num_pages }})value={{ num_pages }};if(value<0)value=1" id="p_num">页&nbsp;</li>
      #这里引入了一个button点击事件#
      <li class="page-item"><button class="page-link" id="submit">确定</button></li></ul>
  </nav>
{% endif %}
  • 点击事件处理
javascript 复制代码
 // 就是一个跳转,本想在这里处理输入页码检查的,觉得麻烦就改成input上的输入限制了。
 $("#submit").click(function () {
      let page_number = $("#p_num").val();
      window.location.href=`?page=${page_number}`  
  });
相关推荐
丕羽3 小时前
【Pytorch】基本语法
人工智能·pytorch·python
bryant_meng3 小时前
【python】Distribution
开发语言·python·分布函数·常用分布
m0_594526304 小时前
Python批量合并多个PDF
java·python·pdf
工业互联网专业4 小时前
Python毕业设计选题:基于Hadoop的租房数据分析系统的设计与实现
vue.js·hadoop·python·flask·毕业设计·源码·课程设计
钱钱钱端5 小时前
【压力测试】如何确定系统最大并发用户数?
自动化测试·软件测试·python·职场和发展·压力测试·postman
慕卿扬5 小时前
基于python的机器学习(二)—— 使用Scikit-learn库
笔记·python·学习·机器学习·scikit-learn
Json____5 小时前
python的安装环境Miniconda(Conda 命令管理依赖配置)
开发语言·python·conda·miniconda
小袁在上班5 小时前
Python 单元测试中的 Mocking 与 Stubbing:提高测试效率的关键技术
python·单元测试·log4j
白狐欧莱雅5 小时前
使用python中的pygame简单实现飞机大战游戏
经验分享·python·游戏·pygame
阿_旭5 小时前
基于YOLO11/v10/v8/v5深度学习的维修工具检测识别系统设计与实现【python源码+Pyqt5界面+数据集+训练代码】
人工智能·python·深度学习·qt·ai