6-Django项目--分页模块化封装参数共存

news2025/1/4 13:22:11

目录

utils/page_data.py

分页模块化封装

在app当中创建一个python package

在当前包里面创建py文件

参数共存

完整代码


utils/page_data.py

--包里创建py文件.

# -*- coding:utf-8 -*-
from django.utils.safestring import mark_safe
from copy import deepcopy

class PageData(object):
    def __init__(self, request, queryset, page_size=10, plus=2, page_param="page"):
        """
            request: 请求
            queryset:数据表查询的结果
            page_size:每页展示多少条数据
            plus:当前页,前后各展示多少个页码
        """
        get_query_dict = deepcopy(request.GET)
        self.query_dict = get_query_dict
        self.page_param = page_param
        # 分页
        page = request.GET.get(page_param, "1")  # 当前所在的页面
        # 判断字符创当中全部都是数字
        if page.isdecimal():
            page = int(page)
        else:
            page = 1

        self.page = page
        self.start = (page - 1) * page_size
        self.end = page * page_size
        # 分页操作
        self.page_queryset = queryset[self.start: self.end]
        page_count = queryset.count()
        page_count, div = divmod(page_count, page_size)
        if div:
            page_count += 1
        self.page_count = page_count
        self.plus = plus

    def page_html(self):
        if self.page_count <= 2 * self.plus + 1:
            start_page = 1
            end_page = self.page_count
        else:
            # 当前选中的页数小于等于三
            if self.page <= self.plus:
                start_page = 1
                end_page = 2 * self.plus + 1
            else:
                # 当前页 + 2
                if (self.page + self.plus) > self.page_count:
                    start_page = self.page_count - self.plus * 2
                    end_page = self.page_count
                else:
                    start_page = self.page - self.plus
                    end_page = self.page + self.plus

        page_str_list = []
        # 首页
        self.query_dict.setlist(self.page_param, [1])
        page_str_list.append(
            f'<li><a href="?{self.query_dict.urlencode()}" aria-label="Previous"><span aria-hidden="true">首页</span></a></li>')

        # 上一页
        if self.page > 1:
            self.query_dict.setlist(self.page_param, [self.page-1])
            page_str_list.append(
                f'<li><a href="?{self.query_dict.urlencode()}" aria-label="Previous"><span aria-hidden="true">«</span></a></li>')
        else:
            page_str_list.append(
                f'<li class="disabled"><a href="#" aria-label="Previous"><span aria-hidden="true">«</span></a></li>')

        for page_num in range(start_page, end_page + 1):
            if page_num == self.page:
                self.query_dict.setlist(self.page_param, [page_num])
                page_ele = f'<li class="active"><a href="?{self.query_dict.urlencode()}">{page_num}</a></li>'
            else:
                self.query_dict.setlist(self.page_param, [page_num])
                page_ele = f'<li><a href="?{self.query_dict.urlencode()}">{page_num}</a></li>'
            page_str_list.append(page_ele)
        # 下一页
        if self.page < self.page_count:
            self.query_dict.setlist(self.page_param, [self.page + 1])
            page_str_list.append(
                f'<li><a href="?{self.query_dict.urlencode()}" aria-label="Next"><span aria-hidden="true">»</span></a></li>')
        else:
            page_str_list.append(
                f'<li class="disabled"><a href="#" aria-label="Next"><span aria-hidden="true">»</span></a></li>')

        # 尾页
        self.query_dict.setlist(self.page_param, [self.page_count])
        page_str_list.append(
            f'<li><a href="?{self.query_dict.urlencode()}" aria-label="Previous"><span aria-hidden="true">尾页</span></a></li>')
        # 将列表当中的字符串传递给html,并且一标签的形式展示
        search_page = """
            <li>
                <form method="get" style="float: left;margin-left: 1px">
                    <input type="text" class="form-control" placeholder="页码" name="page" style="position: relative;display: inline-block;width: 75px">
                    <button class="btn btn-success btn-sm" type="submit">跳转</button>
                </form>
            </li>
            """
        page_str_list.append(search_page)
        page_string = mark_safe("".join(page_str_list))
        return page_string


分页模块化封装

  • 在app当中创建一个python package

  • 在当前包里面创建py文件

    # -*- coding:utf-8 -*-
    from django.utils.safestring import mark_safe
    from copy import deepcopy
    ​
    class PageData(object):
        def __init__(self, request, queryset, page_size=10, plus=2, page_param="page"):
            """
                request: 请求
                queryset:数据表查询的结果
                page_size:每页展示多少条数据
                plus:当前页,前后各展示多少个页码
            """
            get_query_dict = deepcopy(request.GET)
            self.query_dict = get_query_dict
            self.page_param = page_param
            # 分页
            page = request.GET.get(page_param, "1")  # 当前所在的页面
            # 判断字符创当中全部都是数字
            if page.isdecimal():
                page = int(page)
            else:
                page = 1
    ​
            self.page = page
            self.start = (page - 1) * page_size
            self.end = page * page_size
            # 分页操作
            self.page_queryset = queryset[self.start: self.end]
            page_count = queryset.count()
            page_count, div = divmod(page_count, page_size)
            if div:
                page_count += 1
            self.page_count = page_count
            self.plus = plus
    ​
        def page_html(self):
            if self.page_count <= 2 * self.plus + 1:
                start_page = 1
                end_page = self.page_count
            else:
                # 当前选中的页数小于等于三
                if self.page <= self.plus:
                    start_page = 1
                    end_page = 2 * self.plus + 1
                else:
                    # 当前页 + 2
                    if (self.page + self.plus) > self.page_count:
                        start_page = self.page_count - self.plus * 2
                        end_page = self.page_count
                    else:
                        start_page = self.page - self.plus
                        end_page = self.page + self.plus
    ​
            page_str_list = []
            # 首页
            page_str_list.append(
                f'<li><a href="?page=1" aria-label="Previous"><span aria-hidden="true">首页</span></a></li>')
    ​
            # 上一页
            if self.page > 1:
                page_str_list.append(
                    f'<li><a href="?page={self.page - 1}" aria-label="Previous"><span aria-hidden="true">«</span></a></li>')
            else:
                page_str_list.append(
                    f'<li class="disabled"><a href="#" aria-label="Previous"><span aria-hidden="true">«</span></a></li>')
    ​
            for page_num in range(start_page, end_page + 1):
                if page_num == self.page:
                    page_ele = f'<li class="active"><a href="?page={page_num}">{page_num}</a></li>'
                else:
                    page_ele = f'<li><a href="?page={page_num}">{page_num}</a></li>'
                page_str_list.append(page_ele)
            # 下一页
            if self.page < self.page_count:
                page_str_list.append(
                    f'<li><a href="?page={self.page + 1}" aria-label="Next"><span aria-hidden="true">»</span></a></li>')
            else:
                page_str_list.append(
                    f'<li class="disabled"><a href="#" aria-label="Next"><span aria-hidden="true">»</span></a></li>')
    ​
            # 尾页
            page_str_list.append(
                f'<li><a href="?page={self.page_count}" aria-label="Previous"><span aria-hidden="true">尾页</span></a></li>')
            # 将列表当中的字符串传递给html,并且一标签的形式展示
            search_page = """
                <li>
                    <form method="get" style="float: left;margin-left: 1px">
                        <input type="text" class="form-control" placeholder="页码" name="page" style="position: relative;display: inline-block;width: 75px">
                        <button class="btn btn-success btn-sm" type="submit">跳转</button>
                    </form>
                </li>
                """
            page_str_list.append(search_page)
            page_string = mark_safe("".join(page_str_list))
            return page_string

 


参数共存

  • 在做搜索的过程当中,翻页的时候,搜索的条件还在

    在翻页的时候,始终展示搜索出来满足条件的数据

    get_query_dict = deepcopy(request.GET)
        # 在get请求当中,固定存放一个page,有其他参数,不会被替换
        get_query_dict.setlist("page", [1])
        # 将两个参数使用&符号拼接起来
        # ?page=1&search=100
        print(get_query_dict.urlencode())
    # 搜索的时候,出现的参数
        http://127.0.0.1:8000/asset/data/?search=100
    # 做翻页的时候,搜索参数还在
        http://127.0.0.1:8000/asset/data/?search=100&page=3

--无论怎么搜索,查找,都只显示一个参数. 

  • 完整代码

    # -*- coding:utf-8 -*-
    from django.utils.safestring import mark_safe
    from copy import deepcopy
    ​
    class PageData(object):
        def __init__(self, request, queryset, page_size=10, plus=2, page_param="page"):
            """
                request: 请求
                queryset:数据表查询的结果
                page_size:每页展示多少条数据
                plus:当前页,前后各展示多少个页码
            """
            get_query_dict = deepcopy(request.GET)
            self.query_dict = get_query_dict
            self.page_param = page_param
            # 分页
            page = request.GET.get(page_param, "1")  # 当前所在的页面
            # 判断字符创当中全部都是数字
            if page.isdecimal():
                page = int(page)
            else:
                page = 1
    ​
            self.page = page
            self.start = (page - 1) * page_size
            self.end = page * page_size
            # 分页操作
            self.page_queryset = queryset[self.start: self.end]
            page_count = queryset.count()
            page_count, div = divmod(page_count, page_size)
            if div:
                page_count += 1
            self.page_count = page_count
            self.plus = plus
    ​
        def page_html(self):
            if self.page_count <= 2 * self.plus + 1:
                start_page = 1
                end_page = self.page_count
            else:
                # 当前选中的页数小于等于三
                if self.page <= self.plus:
                    start_page = 1
                    end_page = 2 * self.plus + 1
                else:
                    # 当前页 + 2
                    if (self.page + self.plus) > self.page_count:
                        start_page = self.page_count - self.plus * 2
                        end_page = self.page_count
                    else:
                        start_page = self.page - self.plus
                        end_page = self.page + self.plus
    ​
            page_str_list = []
            # 首页
            self.query_dict.setlist(self.page_param, [1])
            page_str_list.append(
                f'<li><a href="?{self.query_dict.urlencode()}" aria-label="Previous"><span aria-hidden="true">首页</span></a></li>')
    ​
            # 上一页
            if self.page > 1:
                self.query_dict.setlist(self.page_param, [self.page-1])
                page_str_list.append(
                    f'<li><a href="?{self.query_dict.urlencode()}" aria-label="Previous"><span aria-hidden="true">«</span></a></li>')
            else:
                page_str_list.append(
                    f'<li class="disabled"><a href="#" aria-label="Previous"><span aria-hidden="true">«</span></a></li>')
    ​
            for page_num in range(start_page, end_page + 1):
                if page_num == self.page:
                    self.query_dict.setlist(self.page_param, [page_num])
                    page_ele = f'<li class="active"><a href="?{self.query_dict.urlencode()}">{page_num}</a></li>'
                else:
                    self.query_dict.setlist(self.page_param, [page_num])
                    page_ele = f'<li><a href="?{self.query_dict.urlencode()}">{page_num}</a></li>'
                page_str_list.append(page_ele)
            # 下一页
            if self.page < self.page_count:
                self.query_dict.setlist(self.page_param, [self.page + 1])
                page_str_list.append(
                    f'<li><a href="?{self.query_dict.urlencode()}" aria-label="Next"><span aria-hidden="true">»</span></a></li>')
            else:
                page_str_list.append(
                    f'<li class="disabled"><a href="#" aria-label="Next"><span aria-hidden="true">»</span></a></li>')
    ​
            # 尾页
            self.query_dict.setlist(self.page_param, [self.page_count])
            page_str_list.append(
                f'<li><a href="?{self.query_dict.urlencode()}" aria-label="Previous"><span aria-hidden="true">尾页</span></a></li>')
            # 将列表当中的字符串传递给html,并且一标签的形式展示
            search_page = """
                <li>
                    <form method="get" style="float: left;margin-left: 1px">
                        <input type="text" class="form-control" placeholder="页码" name="page" style="position: relative;display: inline-block;width: 75px">
                        <button class="btn btn-success btn-sm" type="submit">跳转</button>
                    </form>
                </li>
                """
            page_str_list.append(search_page)
            page_string = mark_safe("".join(page_str_list))
            return page_string

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1718309.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

怎么制作能下载文件的二维码?扫码实现文件下载的方法

现在很多人为了能够方便其他人查看文件&#xff0c;经常会将文件生成二维码图片后&#xff0c;将二维码分享给其他人扫码在手机上查看&#xff0c;这种方式既能够节省成本&#xff0c;又可以实现多人同时获取内容&#xff0c;有利于文件的快速分享。 在制作文件二维码的时候&a…

python数据集优化技巧:统一小分类的方法

新书上架~&#x1f447;全国包邮奥~ python实用小工具开发教程http://pythontoolsteach.com/3 欢迎关注我&#x1f446;&#xff0c;收藏下次不迷路┗|&#xff40;O′|┛ 嗷~~ 目录 一、引言 二、统一小分类的需求与背景 三、统一小分类的步骤与方法 1. 数据集分析 2. 确…

renren-fast-vue启动报错

问题描述 拉取人人开源vue项目启动失败 报错信息 版本信息 序号名称版本号1node14.21.3 启动方案 1.拉取项目 git clone https://gitee.com/renrenio/renren-fast-vue.git 2.执行安装依赖命令 npm install 3.此时报错 chromedriver2.27.2 install: node install.js 4.手动…

二、线性回归模型

目录 一、线性回归 1.模型示例 2.代码实验&#xff08;C1_W1_Lab03_Model_Representation&#xff09; (1).工具使用 (2).问题描述-房价预测 (3).输入数据 (4).绘制数据集坐标点 (5).建模构造函数 二、代价函数&#xff08;Cost function&#xff09; 1.解释一下概念…

3225mm晶振SG3225CAN专用于蓝牙模块应用

在无线通信技术迅猛发展的今天&#xff0c;蓝牙技术因其低功耗、高传输速率和广泛的应用范围&#xff0c;成为物联网和智能设备的重要组成部分。晶振在蓝牙模块中无处不在&#xff0c;大部分的智能手机&#xff0c;打开设置工具里面就会有一个是蓝牙功能&#xff0c;蓝牙技术引…

机器视觉halcon学习——检测斜面两边之间距离的数据稳定性

一个样品的斜面&#xff0c;因为有景深&#xff0c;所以无法同时聚焦到两条边。想办法聚焦到其中一条不太有特征的边&#xff0c;另一条边通过白色的特征来检测。 dev_open_window(0, 0, 800, 800, black, WindowHandle) dev_set_color(red) * Image Acquisition 01: Code gen…

影响生产RAG流水线5大瓶颈

检索增强生成&#xff08;Retrieval Augmented Generation&#xff0c;RAG&#xff09;已成为基于大型语言模型的生成式人工智能应用的关键组成部分。其主要目标是通过将通用语言模型与外部信息检索系统集成&#xff0c;增强通用语言模型的能力。这种混合方法旨在解决传统语言模…

宝塔面板如何创建ZeroTier-Moon节点

本文转自博主的个人博客&#xff1a;https://blog.zhumengmeng.work,欢迎大家前往查看。 原文链接&#xff1a;点我访问 序言&#xff1a;折腾过内网穿透的玩家&#xff0c;ngrok、frp 都应该不陌生了&#xff0c;自己搭也好&#xff0c;用别人提供的免费服务也好&#xff0c;配…

“合力同行 快乐飞凌”——飞凌嵌入式5月团建记

这个5月&#xff0c;飞凌嵌入式全体成员来到了北京十渡东湖港风景区&#xff0c;开展“合力同行 快乐飞凌”主题团建活动 。 1、凝聚力挑战赛 本次团建活动不仅是大家放松心情、享受自然的好机会&#xff0c;更是增进彼此了解、加强团队合作的绝佳平台。 团建活动伊始&#x…

vue UI组件整理

Vue2Vue3Element - The worlds most popular Vue UI frameworkOverview 组件总览 | Element Plushttps://v2.iviewui.com/docs/guide/installhttps://www.iviewui.com/view-ui-plus/guide/introduce按钮 Button - Ant Design按钮 Button - Ant DesignVuetify — A Material Des…

GPT-4o:人工智能技术的新巅峰

人不走空 &#x1f308;个人主页&#xff1a;人不走空 &#x1f496;系列专栏&#xff1a;算法专题 ⏰诗词歌赋&#xff1a;斯是陋室&#xff0c;惟吾德馨 目录 &#x1f308;个人主页&#xff1a;人不走空 &#x1f496;系列专栏&#xff1a;算法专题 ⏰诗词歌…

17.Redis之主从复制

1.主从复制是怎么回事&#xff1f; 分布式系统, 涉及到一个非常关键的问题: 单点问题 单点问题&#xff1a;如果某个服务器程序, 只有一个节点(只搞一个物理服务器, 来部署这个服务器程序) 1.可用性问题,如果这个机器挂了,意味着服务就中断了~ 2.性能/支持的并发量也是比较有限…

Java集合-List(Collection子接口)及其子类(ArrayList、Vector、LinkedList)

List接口是 Collection接口的子接口。 1、List集合类中数据有序&#xff0c; 即添加顺序和取出顺序有序&#xff0c;而且可以重复。 2、List集合类中每个元素都有其对应的顺序索引&#xff0c;即支持索引。例&#xff0c;list.get(2)&#xff1b;取第三个元素。 3、实现类有很多…

【linux-imx6ull-设备树点灯】

目录 1. 设备树简介1.1 编译-引用1.2 设备树文件结构1.3 设备树节点介绍1.3.1 特殊节点chosen 1.4 节点内容追加 2. 设备树常用OF操作函数2.1 节点寻找类2.2 属性提取类2.3 其它常用类 4. 设备树下LED实验4.1 实验简介4.2 添加LED设备节点4.3 获取设备节点并提取属性4.3.1 获取…

ChatTTS,语气韵律媲美真人的开源TTS模型,文字转语音界的新魁首,对标微软Azure-tts

前两天 2noise 团队开源了ChatTTS项目&#xff0c;并且释出了相关的音色模型权重&#xff0c;效果确实非常惊艳&#xff0c;让人一听难忘&#xff0c;即使摆在微软的商业级项目Azure-tts面前&#xff0c;也是毫不逊色的。 ChatTTS是专门为对话场景设计的文本转语音模型&#x…

iphone内存满了开不了机怎么办?白苹果解决办法分享!

虽然苹果手机在使用时比较顺畅&#xff0c;但是手机用久了&#xff0c;照片、视频等资料累积过多&#xff0c;也难免会导致内存不足&#xff0c;出现无法开机卡在开机界面白苹果的情况。 内存不足导致iPhone白苹果的问题很常见&#xff0c;可以说是苹果最常见的故障之一。接下来…

探索多模态MR图像的脑肿瘤分割任务结构| 文献速递-深度学习肿瘤自动分割

Title 题目 Exploring Task Structure for Brain Tumor Segmentation From Multi Modality MR Images 探索多模态MR图像的脑肿瘤分割任务结构 01 文献速递介绍 脑肿瘤分割旨在从多模态磁共振&#xff08;MR&#xff09;序列中自动分割肿瘤区域&#xff0c;这些序列由先进的…

【Java面试】七、SpringMvc的执行流程、SpringBoot自动装配原理

文章目录 1、SpringMVC的执行流程1.1 视图阶段1.2 前后端分离阶段 2、SpringBoot自动配置原理3、框架常用的注解3.1 Spring的注解3.2 SpringMvc的注解3.3 SpringBoot的注解 4、面试 1、SpringMVC的执行流程 1.1 视图阶段 旧项目中&#xff0c;未前后端分离时&#xff0c;用到…

JVM 指针压缩

运用java内存对齐填充&#xff0c;对java内存进行8字节划分&#xff0c;java对象指针映射到每个划分区域上&#xff0c;使得4个字节&#xff08;32位&#xff09;表示2^32个地址&#xff0c;从而使4个字节指针映射32G内存空间。 1.为什么进行指针压缩&#xff1a; jvm从32位变…

【YUV格式数据】【ffplay】播放或者查看YUV格式图片或文件数据

背景 最近在调试hisi解码功能&#xff0c;需要把h264格式解码成yuv数据&#xff0c;调试的时候需要最后查看下出来的yuv格式数据是否正常&#xff0c;需要用到一些工具软件进行查看。然后就做个总结。 解决方案 方案1&#xff1a;使用ffplay命令播放YUV文件 使用ffplay命令…