Springboot+mybatis使用PageHelper实现vue前端分页

news2024/11/17 22:45:47

Springboot+mybatis使用PageHelper实现vue前端分页

  • 1、未分页前的vue前端效果图
  • 2、Springboot+mybatis使用PageHelper分页逻辑:
      • (1)Springboot、mybatis、PageHelper的版本:
      • (2)yml文件配置pagehelper:
      • (3)controller、serviceimpl层级逻辑:
  • 3、前端vue的分页逻辑:
      • (1)外部:
      • (2)内部:
  • 4、分页后的vue前端效果图

1、未分页前的vue前端效果图

在这里插入图片描述

2、Springboot+mybatis使用PageHelper分页逻辑:

(1)Springboot、mybatis、PageHelper的版本:

在这里插入图片描述
在这里插入图片描述

(2)yml文件配置pagehelper:

pagehelper:
    # 分页插件会自动检测当前的数据库链接,自动选择合适的分页方式(可以不设置)
    helper-dialect: mysql
    # 上面数据库设置后,下面的设置为true不会改变上面的结果(默认为true)
    auto-dialect: true
    page-size-zero: false
    reasonable: true
    # 默认值为 false,该参数对使用 RowBounds 作为分页参数时有效。(一般用不着)
    offset-as-page-num: false
    # 默认值为 false,RowBounds是否进行count查询(一般用不着)
    row-bounds-with-count: false
    # 用于控制默认不带 count 查询的方法中,是否执行 count 查询,这里设置为true后,total会为-1
    default-count: false
    supportMethodsArguments: true
    params: count=countSql
    autoRuntimeDialect: true

此处我是配置在spring层级下的:
在这里插入图片描述

(3)controller、serviceimpl层级逻辑:

controller层:要接收前端传的当前页、页面数据量,没有就设置默认值,避免出现异常。
在这里插入图片描述

impl层:Mapper以及Service都不需要更改,直接在impl中加入分页方法即可。
PageHelper.startPage(pageNum, pageSize);
在这里插入图片描述
eg:PageHelper.startPage(2, 10)==>即查询第二页的数据,每页是10条数据。

3、前端vue的分页逻辑:

(1)外部:

如果传入了 page-size,且布局包含 page-size 选择器(即 layout 包含 sizes),必须监听 page-size 变更的事件。

<Switch v-model:value="status" /> //v-model等价于@update:value="status=$event"

<el-pagination
                v-model:current-page="currentPage"
                v-model:page-size="pageSize"
                :small="small"
                :disabled="disabled"
                :background="background"
                layout="sizes, prev, pager, next"
                :total="countProducts"
                @size-change="handleSizeChange"
                @current-change="handleSizeChange"
        />

在这里插入图片描述

(2)内部:

前端设置默认赋值:

data () {
            return {
                // accountInfo数据绑定对象
                productInfos: [],
                show: true,
                countProducts: 20,//总数据默认20条
                currentPage: 1,//默认当前第一页
                pageSize: 10,//页面大小,默认十条
                selectMode: 'single'
            }
        }

在这里插入图片描述

内部的请求方法:

进入列表时自动请求展示数据(第一页的10条数据,以及获取总数分页码)

productInfo() {
                const proInfo = this.$http.post('productByPage')
                proInfo.then((dd) => {
                    const res = dd
                    console.log(res)
                    if (res.data.code !== 1) {
                        alert("发生某些错误,请重试")
                        this.$router.push('/userIndex')
                    }
                    // turn in /home
                    if (res.data.code === 1)
                        this.productInfos = res.data.data
                    console.log(this.productInfos)
                })

                const countProduct = this.$http.post('productTotal')
                countProduct.then((dd) => {
                    const res = dd
                    console.log(res)
                    if (res.data.code !== 1) {
                        alert("发生某些错误,请重试")
                        this.$router.push('/userIndex')
                    }
                    // turn in /home
                    if (res.data.code === 1)
                        this.countProducts = res.data.data
                    console.log(this.countProducts)
                })
            }

在这里插入图片描述

切换页码时下一页或者指定页码的请求方法:此处切换页面数据量大小(外部对应@current-change=“handleSizeChange”)和切换页码(外部对应@size-change=“handleSizeChange”)均用此方法。

handleSizeChange(){
                const proInfo = this.$http.post('productByPage?pageNum='+ this.currentPage + '&pageSize=' +this.pageSize)
                proInfo.then((dd) => {
                    const res = dd
                    console.log(res)
                    if (res.data.code !== 1) {
                        alert("发生某些错误,请重试")
                        this.$router.push('/userIndex')
                    }
                    // turn in /home
                    if (res.data.code === 1)
                        this.productInfos = res.data.data
                    console.log(this.productInfos)
                })

                const countProduct = this.$http.post('productTotal')
                countProduct.then((dd) => {
                    const res = dd
                    console.log(res)
                    if (res.data.code !== 1) {
                        alert("发生某些错误,请重试")
                        this.$router.push('/userIndex')
                    }
                    // turn in /home
                    if (res.data.code === 1)
                        this.countProducts = res.data.data
                    console.log(this.countProducts)
                })
            }

在这里插入图片描述

4、分页后的vue前端效果图

在这里插入图片描述
在这里插入图片描述

至此,Springboot+mybatis使用PageHelper实现了vue前端分页功能(支持页码切换和展示的数据量切换)。

参考资料:
1、vue-element3官方分页组件使用:https://element-plus.gitee.io/zh-CN/component/pagination.html
2、你不知道的PageHelper:(主要参考配置文件需要配置的参数)https://zhuanlan.zhihu.com/p/77147210

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

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

相关文章

带你了解docker是什么----初始篇

docker容器docker简介docker、虚拟环境与虚拟机docker 的核心概念Docker 镜像Docker 仓库Docker容器镜像、容器、仓库&#xff0c;三者之间的联系容器 容器一词的英文是container&#xff0c;其实container还有集装箱的意思&#xff0c;集装箱绝对是商业史上了不起的一项发明&…

11.3 关联容器操作

文章目录关联容器迭代器关键字成员不可修改&#xff0c;值可修改关于泛型算法添加元素向set插入元素向map插入数据insert操作总结检测insert的返回值展开递增语句向multiset和multimap添加元素删除元素map下标操作访问元素类型别名&#xff1a;类型别名说明key_type关键字类型&…

第一个Spring、第一个SpringBoot、Spring-Mybatis整合、SpringBoot-Mybatis整合

目录一、第一个Spring程序二、第一个SpringBoot三、Spring-Mybatis整合四、SpringBoot-Mybatis整合第一个程序一、第一个Spring程序 添加依赖——用以支持spring <dependency><groupId>org.springframework</groupId><artifactId>spring-webmvc</a…

线程池的简单介绍以及实现一个线程池

文章目录1、线程池存在的意义2、什么是线程池&#xff1f;3、线程池的使用2、java标准库中的线程池3、认识一下不同的线程池&#xff1a;4、认识一下线程池里的参数&#xff1a;4、实现一个简单的线程池1、线程池存在的意义 线程存在的意义&#xff1a;使用进程来实现并发编程…

鼠标右键没有git bash here(图文详解)

升级Win11后突然发现右键没有git bash here了解决&#xff1a;1. winr键&#xff0c;打开命令窗口,输入regedit打开注册表2. 在注册表中按照路径打开\HKEY_CLASSES_ROOT\Directory\Background\shell\3. 在shell上右键新建项&#xff0c;取名Git Bash Here&#xff0c;再点击Git…

SpringCloudConsul

上篇文章注册中心选出了Consul 和 K8S&#xff0c;现在我需要把他们集成到SpringCloud里&#xff0c;体验一下他们的服务注册发现、动态配置与权限分配难易 问题&#xff0c;以便选出更适合我们的。SpringCloudConsul首先用Docker搭建出Consul集群&#xff0c;这一步忽略了&…

8、Ubuntu22.4Server安装MariaDB10.10初始化密码Navicat远程登录

安装MariaDB10.10 查找源 apt search mariadb 在Ubuntu系统上从MariaDB存储库安装MariaDB10.10时&#xff0c;需要运行以下命令 sudo apt-get install apt-transport-https curl sudo curl -o /etc/apt/trusted.gpg.d/mariadb_release_signing_key.asc https://mariadb.org…

【微服务】Feign远程调用

本系列介绍的是Spring Cloud中涉及的知识点&#xff0c;如有错误欢迎指出~ 一.引子 我们以前基于RestTemplate发起的http请求远程调用服务&#xff1a; 存在下面的问题&#xff1a; 代码可读性差&#xff0c;编程体验不统一 参数复杂URL难以维护&#xff0c;字符串拼接硬编码…

逆卷积(ConvTranspose2d)是什么?

上图是一个卷积操作&#xff08;蓝色为输入&#xff0c;绿色为输出&#xff09;。 输入的特征图为x&#xff1a;( 4&#xff0c;4 &#xff0c;channels_in&#xff09;其中channels_in表示通道数。 卷积核设置&#xff1a;无padding&#xff0c; kernel size为3*3&#xff0c…

<关键字(1)>——《C语言深度剖析》

目录 关键字 - 第一讲 1.关键字分类 2.定义与声明 2.1 什么是变量(是什么) 2.2如何定义变量(怎么用) 2.3为什么要定义变量(为什么) 2.4 变量定义的本质 2.5 变量声明的本质 3. 最宽宏大量的关键字 - auto 3.1 变量的分类 3.2 变量的作用域 3.3 变量的生命周期 …

汇编语言(第四版)第八章 实验7 习题解答

Power idea 公司从1975年成立一直到1995年的基本情况如下&#xff1a; 下面的程序中&#xff0c;已经定义好了这些数据&#xff1a; assume cs:codesg,ds:datasgdatasg segmentdb 1975,1976,1977,1978,1979,1980,1981,1982,1983db 1984,1985,1986,1987,1988,1989,1990,1991,19…

【12】C语言_几个循环的经典练习

目录 1. 打印n的阶乘; 2、计算 1!2!3!......10! 3、用二分查找在一个有序数组中查找一个数 4、打印如下 5、输入三次密码 6、写一个猜数字游戏 7、如题 8、打印1到100之间 3的倍数 9、给两个数&#xff0c;求出最大公约数 10、找出从1000到2000之间的闰年 11、找出10…

Java是编译性语言还是解释型语言 ?

首先我们应该了解这两种语言的概念 . 高级语言在计算机上执行 , 有两种方式 , 分为编译型语言和解释型语言 . 编译型语言 : 编写源代码–>编译–>链接. 典型的编译型语言 : C/C . 特点 : 源代码中一处有错 , 就不允许编译 ; 编译过程中出现一处错误 , 就停止编译 . 优…

论文投稿指南——中文核心期刊推荐(武器工业)

【前言】 &#x1f680; 想发论文怎么办&#xff1f;手把手教你论文如何投稿&#xff01;那么&#xff0c;首先要搞懂投稿目标——论文期刊 &#x1f384; 在期刊论文的分布中&#xff0c;存在一种普遍现象&#xff1a;即对于某一特定的学科或专业来说&#xff0c;少数期刊所含…

4个免费数据恢复软件:免费恢复您的数据

意外的文件删除或文件损坏可能会令人头疼&#xff0c;尤其是在您不使用云存储的情况下。两者通常都支持已删除的文件恢复和版本控制&#xff0c;以帮助您摆脱此类困境。如果您不使用云&#xff0c;通常唯一的机会就是使用数据恢复软件来找回丢失或损坏的数据。 这种方法有两个…

使用 Burpsuite 测试的常用操作(二)

大家好啊&#xff0c;我是大田。接上篇文章「 使用 Burpsuite 测试的常用操作&#xff08;一&#xff09;」&#xff0c;今天继续分享一下 Burpsuite 在工作中常用操作三、本文中 2 个常用操作1、Burpsuite_proxy 篡改请求通过代理模式可以拦截、查看、修改所有客户端和服务器端…

(二)Linux嵌入式开发——软件安装(Ubuntu)

文章目录&#xff08;二)Linux嵌入式开发——软件安装&#xff08;Ubuntu&#xff09;APP StoreAPT工具问题解决办法1解决办法2deb软件包程序源码问题1解决办法问题2解决办法总结&#xff08;二)Linux嵌入式开发——软件安装&#xff08;Ubuntu&#xff09; 接下来&#xff0c;…

【GD32F427开发板试用】FOC矢量算法研究系列之一:PWM实现呼吸灯

本篇文章来自极术社区与兆易创新组织的GD32F427开发板评测活动&#xff0c;更多开发板试用活动请关注极术社区网站。作者&#xff1a;Q_dGHvwj 前言 有幸被选为此次开发板测评活动的参与者&#xff0c;万分感谢。收到板子后迫不及待的拆来查看&#xff0c;画风整齐美观&#x…

SpringCloudAlibabaNacosConfig学习笔记

目录 1. Nacos配置中心使用 2 搭建nacos-config服务 3 Config相关配置 4 .配置的优先级 5. RefreshScope 1. Nacos配置中心使用 官方文档&#xff1a; https://github.com/alibaba/springcloudalibaba/wiki/Nacosconfig Nacos 提供用于存储配置和其他元数据的key/value 存…

23种设计模式(十三)——代理模式【接口隔离】

文章目录 意图什么时候使用代理真实世界类比代理模式的实现代理模式的优缺点亦称:Proxy 意图 由于某些原因需要给某对象提供一个代理以控制对该对象的访问。这时,访问对象不适合或者不能直接引用目标对象,代理对象作为访问对象和目标对象之间的中介。 什么时候使用代理 1、…