SSMP整合案例(14) 将界面查询改为分页查询

news2024/11/16 22:51:07

前面几篇文章过后 我们的项目基本环境就算搭好了
但是 我们下面的分页显然就是个摆设
在这里插入图片描述
这里 我们就先将查询的方法改成分页的

我们 java项目之前做了这个分页的函数
在这里插入图片描述
那么 我们vue项目 直接在 src下的 api 下的bookApi.js中加上对应的函数

export function getPage(params){
    return request({
        url:`/books/page`,
        method:'get',
        params:params,
    })
}

因为 我们的分页方法上面单独挂了 @GetMapping(“/page”) 多声明了一节路径 所以 我们这里是/books/page

然后 我们来到App.vue组件
在这里插入图片描述
可以看到 我们的声明周期中调用的是 getAll 函数 是查询全部的函数 而我们的data中其实之前就写好了分页的参数了
在这里插入图片描述
首先 我们在 App.vue中引入我们刚刚写的getPage
在这里插入图片描述

然后 我们在这个组件中单独写一个getPages函数

getPage(data).then(res => {
  if(res.state == 200) {
     this.total = res.data.total;
     this.bookList = res.data.records;
   }else{
     this.$message.error(res.message);
   }
 })

然后 在 mounted中调用它
在这里插入图片描述
运行代码
在这里插入图片描述
可以看到 我们下面分页的效果也出来了

那么 我们之前调用的 查询全局的代码都要改一改 其实就两个地方 一个是 App组件中传给bookFill的getAll
在这里插入图片描述
还有一个就是删除成功之后的getAll
在这里插入图片描述
这里 我们都换成getPages
好在用的地方不多 比较好换

但是 我们会发现 现在点击 第二页是没有反应的
在这里插入图片描述
因为我们并没有编写切换当前页的一个逻辑
我们将分页组件的代码改成这样

<el-pagination
   background
  :page-size="page.pageSize"
  :page-count="page.pageCount"
  layout="sizes, prev, pager, next"
  @size-change="handleSizeChange"
  @current-change="handleCurrentChange"
  :total="total">
</el-pagination>

首先 我们改了一下layout
最明显的变化就是 最开始的sizes 可以调整每页展示条数
在这里插入图片描述
然后 size-change 当用户切换每页展示条数时触发的方法 current-change 当用户切换当前页时 触发的函数

我们可以在methods中编写这两个对应的函数

handleSizeChange(value) {
 this.page.pageCount = 1;
  this.page.pageSize = value;
  this.getPages();
},
handleCurrentChange(value) {
  this.page.pageCount = value;
  this.getPages();
},

在这里插入图片描述
当用户切换当前页 我们直接 改变当前页的this.page.pageCount 然后重新调用查询即可
然后 当用户切换当前页展示多少条 时 先将当前页变回第一页 在开发中我建议 只要查询条件改变都将当前页变为第一页 可以规避非常多问题 因为条件不一样 查出来的数据总页数会有不同
例如 你当前在第五页 条件改了 但他这个条件只能查到四页数据 然后你当前页发的5 自然就会出问题
好 然后我们运行代码

可以看到 我们点击第二页显然没什么问题
在这里插入图片描述
然后 我们将每页展示的条数调成20
在这里插入图片描述

可以看到我们的分页也是及时的做出了处理
在这里插入图片描述

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

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

相关文章

动态SLAM论文(8) — DynaSLAM II: Tightly-Coupled Multi-Object Tracking and SLAM

目录 1 Introduction 2 Related Work 3 Method A. 符号表示 B. 物体数据关联 C. 以对象为中心的表示 D. 对象束调整 E. 边界框 4 Experiments A. 视觉里程计 B. 多目标跟踪 C. 时间分析 5 结论和未来工作 摘要 —— 在视觉SLAM算法中&#xff0c;假设场景是刚性的是…

快速入门uniapp——从环境搭建到项目实践

&#x1f642;博主&#xff1a;小猫娃来啦 &#x1f642;文章核心&#xff1a;快速入门uniapp——从环境搭建到项目实践 文章目录 初步介绍UniApp开发环境搭建下载和安装UniApp开发工具创建新项目&#xff08;HBuilderX&#xff09;开发工具界面介绍 UniApp基础知识页面结构页面…

Rdkit|SMARTS语言应用

github&#xff1a;地址 文章目录 Rdkit|SMARTS语言应用子结构搜索HasSubstructMatch(patt)得到子结构序列GetSubstructMatch删除子结构AllChem.DeleteSubstructs(m,patt)取代基替换AllChem.ReplaceSubstructs(m, patt, rep)显示核心结构显示侧链结构 Chem.ReplaceCore分子拆分…

vue transition标签用法

transition标签 是Vue的内置动画标签&#xff0c;在插入/更新/移除DOM元素时&#xff0c;在合适的时候给元素添加样式类名&#xff08;配合css样式使用&#xff0c;实现动画效果&#xff09; 注意&#xff1a; 1.transition标签只能包含一个元素&#xff1b;如果里面写了多个…

如何从零开始学习自动化测试?终于找到靠谱的教程了

目录 前言 测试基础 Python基础 selenium appium requests unittest 项目实战&#xff1a; 总结&#xff1a; 前言 最近有几个小伙伴在后台给安静私信说&#xff0c;如何学习自动化&#xff0c;不知道如何入手&#xff1f;在网上看的资料都是乱七八糟的&#xff0c;每…

接口返回慢 图片加载失败问题

该图片是通过后端接口返回picUrl来给img的src赋值 但是后端接口响应较慢 导致html加载完 data也没赋到值 图片加载裂开 解决办法&#xff1a;img标签添加error事件获取错误信息回调 <img v-if"certificateUrl" :src"certificateUrl" class"certif…

三星强势进军车用半导体,2025年开始提供8英寸氮化镓代工服务

根据来自韩国商业报导的消息&#xff0c;三星电子最近在美国和韩国两地举办了一个专门针对行业人士的论坛&#xff0c;旨在展示2023年的三星晶圆代工技术。在这次活动中&#xff0c;三星宣布将在2025年开始提供面向消费者、数据中心及汽车应用的8英寸氮化镓&#xff08;GaN&…

如何关闭电脑自动更新

文章目录 前言Win10操作第一种&#xff1a;停止Windows Update第二种&#xff1a; 更新和安全暂停更新xxx天 Win11操作总结 前言 提示&#xff1a;这里可以添加本文要记录的大概内容&#xff1a; 关闭有关闭的好处&#xff1b;更新有更新的好处。谨慎操作&#xff01; 1、如…

123.【SpringBoot 源码刨析B】

SpringBoot-核心功能 (三)、SpringBoot核心功能1.配置文件1.1、properties1.2、yaml(1).yaml 简介(2).yaml 基本语法(3).数据类型(4).示列 1.3、配置提示 2.WEB 开发1.SpringMVC自动配置概览2.简单功能分析(1).静态资源访问&#xff08;1.1&#xff09;.静态资源目录&#xff0…

CentOS7安装后不能复制解决方案

CentOS7安装后无法使用鼠标选中&#xff0c;复制问题解决 yum命令安装gpm &#xff1a; yum install gpm* 运行systemctl enable gpm.servicere 添加到后台服务 启动&#xff1a; systemctl start gpm.service 查看启动状态: systemctl status gpm.service CentOS7服务使…

自制游戏引擎之shader预编译

shader预编译为二进制,在程序运行时候加载,可以提升性能,节省启动时间. 1. 采用google shaderc预编译与加载shader 1.1 下载代码 https://github.com/google/shaderc third_party文件里需要放依赖的第三方 因为电脑访问google的问题,无法通过shaderc-2023.4\utils\git-sync-de…

雅特力 AT32F437 配置RT-Thread 以太网(UDP/TCP Server)

好记性不如烂笔头&#xff0c;既然不够聪明&#xff0c;就乖乖的做笔记&#xff0c;温故而知新。 本文档用于本人对知识点的梳理和记录。 雅特力 AT32F437 配置RT-Thread 以太网(UDP/TCP Server) 目录 一、前言 二、ENV配置 三、结语 一、前言 ENV版本&#xff1a;v1.3.5 rt-…

【深度学习】AIGC ,ControlNet 论文,原理,训练,部署,实战,教程(一)

论文&#xff1a;https://arxiv.53yu.com/pdf/2302.05543 代码&#xff1a;https://github.com/lllyasviel/ControlNet 得分几个博客完成这个事情的记录了&#xff0c;此篇是第一篇&#xff0c;摘录了一些论文内容。ControlNet 的原理极为朴实无华&#xff08;对每个block添加…

软件设计模式与体系结构-设计模式-行为型软件设计模式-状态模式

五、状态模式 概念 与策略模式类似&#xff0c;状态模式将不同状态下的行为封装在不同的类中&#xff0c;每个类代表一个状态 状态模式的组成 Context&#xff1a;定义了与客户程序的接口&#xff0c;它保持了一个concreteState的代表现在状态的实例State&#xff1a;定义了…

怎么用转转大师工具旋转PDF文件页面

有时候我们会在网上下载一下PDF格式文件&#xff0c;下载的PDF文件中可能会出现页面倒过来的情况&#xff0c;遇到这种情况我们需要先将PDF文件旋转到正确的角度才能继续阅读使用&#xff0c;那么有哪些方法可以快速旋转PDF页面呢&#xff1f; 可以使用转转大师工具快速旋转PD…

【知识产权-01】知识产权建设之专利那些事

在当今信息爆炸的时代&#xff0c;知识产权的保护变得尤为重要。专利是知识产权的一种重要形式&#xff0c;它是创新和发明的重要保护手段。几张图片向大家介绍专利的审查流程、不同方式的审查周期、专利检索以及技术交底书的基本知识&#xff0c;方便大家查阅。 审查流程 审查…

JavaWeb——HTTPS的加密流程

目录 一、使用对称加密 1、定义 2、加密/解密过程 二、使用非对称加密 1、对称加密弱点 2、非对称加密过程 &#xff08;1&#xff09;、定义 &#xff08;2&#xff09;、加密/解密过程 三、使用证书加密 1、非对称加密弱点 2、使用证书加密过程 &#xff08;1&am…

k8s概念介绍

目录 一 整体架构和组件基本概念 1.1 组件 1.1.1 master节点 1.1.2 node节点 1.1.3 附加组件 二 资源和对象 2.1 资源分类 2.2 元数据资源 Horizontal Pod Autoscaler&#xff08;HPA&#xff09; PodTemplate LimitRange 2.3 集群资源 namespace Node ClusterRo…

树状数组详解

问题引入 为了做到对区间的快速查询&#xff0c;可能你会想到前缀和来优化这个查询&#xff0c;这样区间查询的话是O(1)的复杂度。但如果发生了单点更新&#xff0c;在之后的所有前缀和都要更新&#xff0c;修改的时间复杂度是O(n)&#xff0c;并不能解决问题。 线段树 为了避…

自动化构建工具(Makefile/make)

什么是自动化构建工具 俗话说,会不会写Makefile可以从侧面表达出一个人是否具有完成大型项目的能力。试想一下&#xff0c;一个工程里面有数不尽的源文件&#xff0c;按照各自的&#xff0c;模块&#xff0c;类型放在不同的目录中&#xff0c;如果我要要去编译这个源文件&…